写点什么

为 NGINX 配置免费的 Let’s Encrypt SSL/TLS 证书

  • 2023-04-05
    北京
  • 本文字数:1683 字

    阅读完需:约 6 分钟

为 NGINX 配置免费的 Let’s Encrypt SSL/TLS 证书

原文作者:Amir Rawdat

原文链接:为 NGINX 配置免费的 Let’s Encrypt SSL/TLS 证书

转载来源:NGINX 官方网站


NGINX 唯一中文官方社区 ,尽在 http://nginx.org.cn/


众所周知,网站的 SSL/TLS 加密会为您的用户带来更靠前的搜索排名和更出色的安全性。但目前有许多障碍阻碍了网站所有者采用 SSL。

其中两个最大障碍是证书获取成本高昂和所涉人工流程繁琐。而现在,有了 Let’s Encrypt,这些都不再是问题。Let’s Encrypt 支持所有人免费使用 SSL/TLS 加密。

Let’s Encrypt 是一家免费、开放、自动化的证书颁发机构 (CA)。是的,没错 Let’s Encrypt 颁发的 SSL/TLS 证书是免费的。现今的大多数浏览器都信任 Let’s Encrypt 颁发的证书,包括旧版浏览器,例如 Windows XP SP3 上的 Internet Explorer。此外,Let’s Encrypt 实现了证书颁发和更新的全自动化。

NGINX 对于成为 Let’s Encrypt 的赞助者之一感到非常骄傲,阅读 《支持开源,打造更安全的世界:F5 NGINX 宣布赞助 Let’s Encrypt 和 OpenSSL》一文了解更多。

本文介绍了如何使用 Let’s Encrypt 客户端生成证书,以及如何自动配置 NGINX 开源版和 NGINX Plus 以使用这些证书。

Let’s Encrypt 的工作原理

在颁发证书之前,Let’s Encrypt 会验证域名的所有权。在您的主机上运行的 Let’s Encrypt 客户端将创建一个临时文件(一个令牌),其中包含所需的信息。然后,Let’s Encrypt 验证服务器会发出 HTTP 请求以检索文件并验证令牌,从而验证您域名的 DNS 记录是否解析到运行 Let’s Encrypt 客户端的服务器。

准备工作

在开始使用 Let’s Encrypt 之前,您需要:

  • 安装 NGINX 开源版或 NGINX Plus

  • 拥有或管理需安装证书的注册域名。如果没有注册域名,您可以在域名注册商处申请。

  • 创建一条 DNS 记录,将您的域名和服务器的公共 IP 地址关联。

现在您可以用 NGINX 开源版或 NGINX Plus 轻松设置 Let’s Encrypt (为了便于阅读,下文将统称为 NGINX)。

注:我们在 Ubuntu 16.04 (Xenial) 上测试了本文所述的程序。

1、下载 Let’s Encrypt 客户端

首先,下载 Let’s Encrypt 客户端 certbot

如上所述,我们在 Ubuntu 16.04 上测试了相关指令,以下是在该平台上运行的相应命令:

$ apt-get update$ sudo apt-get install certbot$ apt-get install python-certbot-nginx
复制代码

用 Ubuntu 18.04 和更高版本, 替代 Python 3 版本:

$ apt-get update$ sudo apt-get install certbot$ apt-get install python3-certbot-nginx
复制代码

2、设置 NGINX

certbot 可以自动完成 NGINX 的 SSL/TLS 配置。它会在您的 NGINX 配置中查找并修改包含 server_name 指令(含有您为其请求证书的域名)的 server 块。在我们的示例中,域名为 www.example.com.

  1. 假设您在一个全新的 NGINX 安装上进行设置,请使用文本编辑器在 /etc/nginx/conf.d 目录中创建一个名为 domain‑name.conf 的文件(在我们的示例中为 www.example.com.conf)。

  2. 使用 server_name 指令指定您的域名(如果域名有变体的话也请指定):

server {    listen 80 default_server;    listen [::]:80 default_server;    root /var/www/html;    server_name example.com www.example.com;}
复制代码
  1. 保存文件,然后运行以下命令来验证配置的语法并重新启动 NGINX:

$ nginx -t && nginx -s reload
复制代码

3、获取 SSL/TLS 证书

certbot 的 NGINX 插件负责重新配置 NGINX,并在必要时重新加载其配置。

  1. 运行以下命令,使用 NGINX 插件生成证书:

$ sudo certbot --nginx -d example.com -d www.example.com
复制代码
  1. 根据 certbot 的提示配置 HTTPS 设置,包括输入您的电子邮件地址并同意 Let’s Encrypt 服务条款。证书生成后,NGINX 重新加载新设置。certbot 生成一条消息,显示证书成功生成,并指示证书在服务器上的位置。

如欲了解本文后续内容,请点击《为 NGINX 配置免费的 Let’s Encrypt SSL/TLS 》证书查看后续内容。


NGINX 唯一中文官方社区 ,尽在 http://nginx.org.cn/

更多 NGINX 相关的技术干货、互动问答、系列课程、活动资源:

用户头像

NGINX唯一中文官方社区 2022-07-04 加入

- 微信公众号:https://mp.weixin.qq.com/s/XVE5yvDbmJtpV2alsIFwJg - 微信群:https://www.nginx.org.cn/static/pc/images/homePage/QR-code.png?v=1621313354 - B站:https://space.bilibili.com/628384319

评论

发布
暂无评论
为 NGINX 配置免费的 Let’s Encrypt SSL/TLS 证书_NGINX开源社区_InfoQ写作社区