给你的网站加把锁 — Let’s Encrypt 完全体验

发布于 2020-12-13  410 次阅读


原文地址

今天抽时间将所有的网站 SSL 证书都更新了成 Let’s Encrypt 了。采用了 certbot 这样的自动化工具,配置管理起来非常容易 (一本正经的胡说八道),这里将对整个体验过程做个详细记录。

The project aims to make encrypted connections in the World Wide Web the default case. By getting rid of payment, web server configuration, validation emails and dealing with expired certificates it is meant to significantly lower the complexity of setting up and maintaining TLS encryption.On a Linux web server, execution of only two commands is sufficient to set up HTTPS encryption, acquire and install certificates within 20 to 30 seconds.

Let’s Encrypt 是一个 2015 年末推出的数字证书认证机构,将通过旨在消除当前手动创建和安装证书的复杂过程的自动化流程,为安全网站提供免费的 SSL/TLS 证书。


Let’s Encrypt 证书生成不需要手动进行,官方推荐 Certbot 这套自动化工具来实现。4 步轻松搞定:

  • 下载安装 certbot (Let’s Encrypt 项目的自动化工具)
  • 获得 SSL 证书
  • 修改 Nginx 配置文件
  • 续订

1. 安装 Certbot

根据 Certbot 官网指南,Debian 8上执行如下命令,安装 certbot:

$ sudo apt-get update
$ sudo apt-get install certbot -t jessie-backports

等安装完成,certbot就可以使用了。

2. 获取 SSL 证书

Let’s Encrypt 提供了通过各种插件获取 SSL 证书的各种方法。不同的是 Apache 的插件,大多数的插件只会帮助你得到,你必须手动配置你的 Web 服务器使用证书。仅获取证书而不安装证书的插件称为 “验证器”,因为它们用于验证服务器是否应颁发证书。
下面将使用Webroot的插件来获取 SSL 证书。

如何使用 Webroot 插件:

Webroot 的工作插件放置在一个特殊的文件/.well-known目录文档根目录下,它可以打开(通过 Web 服务器)内由让我们的加密服务进行验证。 根据配置的不同,你可能需要明确允许访问 /.well-known 目录。

为了确保该目录可供 Let’s Encrypt 进行验证,让我们快速更改我们的 Nginx 配置。编辑/etc/nginx/conf.d/example.com.conf文件,并将下面代码添加进去:

location ~ /.well-known {
    allow all;
}

使用nginx -t测试配置文件是否正确,在正确的情况下,重新让 Nginx 重新加载配置文件:

$ sudo systemctl reload nginx

使用 certbot 命令获取证书:

$ sudo certbot certonly --webroot -w /var/www/example -d example.com -d www.example.com -w /var/www/thing -d thing.is -d m.thing.is
  • -w: 指定网站所在目录
  • -d: 指定要生成证书的域名,如果你想多个域名保存在一个证书里 (最多四个)(如example.comwww.example.comthing.ism.thing.is),请确保使用适当的 webroot 路径和域名替换命令中的相对应部分。

接下来,同意加密订阅协议:

如果一切顺利,你应该看到一个类似下面的输出消息:

IMPORTANT NOTES:

  • Congratulations! Your certificate and chain have been saved at
    /etc/letsencrypt/live/example.com/fullchain.pem. Your cert will expire
    on 2017-06-19. To obtain a new or tweaked version of this
    certificate in the future, simply run certbot again. To
    non-interactively renew all of your certificates, run “certbot
    renew”
  • If you like Certbot, please consider supporting our work by:

    Donating to ISRG / Let’s Encrypt: https://letsencrypt.org/donate
    Donating to EFF: https://eff.org/donate-le

证书文件

如果运行顺利,所有服务器所需要的证书就已经生成好了。他们被放在了 /etc/letsencrypt/live/example.com/ 下:

$ ls /etc/letsencrypt/live/example.com/
cert.pem 
privkey.pem 
chain.pem 
fullchain.pem

3. 修改 Nginx 配置文件

到这里已经成功一大半了,只需要配置 Nginx 支持刚刚生成的证书。最佳实践可以参考 Mozilla SSL Configuration Generator

注意去掉 HSTS 的勾 (勾上会强制 https,并且很难消除后续影响)。

请根据自己的服务配置修改和添加内容,重点只需要关注 6 行

server {  
    listen 443 ssl http2;
    ....
    ssl_certificate /etc/letsencrypt/live/example.com/fullchain.pem;
    ssl_certificate_key /etc/letsencrypt/live/example.com/privkey.pem;
    ssl_dhparam /etc/nginx/ssl/dhparam.pem;

    ssl_trusted_certificate /etc/letsencrypt/live/example.com/root_ca_cert_plus_intermediates;

    resolver <IP DNS resolver>;
    ....
}

dhparam.pem可以通过以下命令生成:

$ sudo mkdir /etc/nginx/ssl
$ sudo openssl dhparam -out /etc/nginx/ssl/dhparam.pem 2048

Nginx 配置完成后重启,用浏览器测试是否一切正常。

4. 续订

Let's Encrypt证书有效期只有 3 个月,所以,需要定时 renew。我将使用corntab来执行 renew 命令:

$ sudo crontab -e

添加以下行:

30 2 * * 1 /usr/bin/certbot renew >> /var/log/le-renew.log && /bin/systemctl reload nginx

保存,并退出。这个定时任务将在每个星期一的凌晨两点半执行certbot renew命令,并重启 Nginx。最后将日志输出到/var/log/le-renewal.log

Qualys SSL Labs 提供了全面的 SSL 安全性测试,填写你的网站域名,给自己的 HTTPS 配置打个分。

这意味着你网站的 HTTPS 已经启用成功啦,为自己鼓个掌。 (๑•̀ㅂ•́)و✧。

还有一种方法,不需要访问你的网站目录,但需要临时停止 Nginx 服务器 (需要用到 80 端口):

  1. 停止 Nginx
  2. 域名解析到你的服务器 IP
  3. 执行命令:certbot certonly --standalone -d example.com -d www.example.com

然后的步骤就和上面一样啦~~~

以上。


或许明日太阳西下倦鸟已归时