zoukankan      html  css  js  c++  java
  • let's encrypt 以dns方式 做https加密

    前言

    昨天在配置网站的时候,我使用了nginx做内部转发。

    按照一般的做法,配置好网站、nginx、certbot后,我们启动nginx,然后使用certbot颁发证书,就可以了。

    但是昨天,就没有生效。

    我上网查了查资料,发现let's encrypt有两种颁发证书的方式,一种是http,也就是我上面说的这种方式;另一种是dns,是一种船新的玩法(其实也不新,之前也见过,但是由于我当时用的还是渣tplink的二级域名,就没法用的那种)。

    按照教程搞了一波,发现还行,特此记录。

    前提

    首先声明,使用let's encrypt对网站进行https加密时,需要以下前提:

    1. nginx监听80端口,且80端口放通。
    2. 目标网站运行正常。
    3. 可以通过nginx转发到目标网站。

    DNS对网站加密的步骤

    1. 运行以下命令:

      certbot certonly -d eryoung2.me --preferred-challenges dns --manual --server https://acme-v02.api.letsencrypt.org/directory  #eryoung2.me是我的域名,通过域名解析挂在了本服务器上
      

      按照提示输入必要信息后(主要就是邮箱啦),就会出现此提示:

      -------------------------------------------------------------------------------
      Please deploy a DNS TXT record under the name
      _acme-challenge.eryoung2.me with the following value:
      
      MlXldX2Pj0fA16gsnHn8lfCP0pbRfVSO5gLCto1m7gE
      
      Once this is deployed,
      -------------------------------------------------------------------------------
      Press Enter to Continue
      
    2. 这时,去到域名供应商的域名解析界面,按照上面的提示添加一条TXT解析。

      主机: _acme-challenge

      记录: MlXldX2Pj0fA16gsnHn8lfCP0pbRfVSO5gLCto1m7gE

      如图所示:

      然后在服务器上点击回车,证书就可以颁发下来了。

    3. 成功后,我们可以使用certbot certificates来检查证书状态。

      需要注意的是,let's encrypt的证书有效期为90天,需要定时续期。

      续期可以通过定时任务来做,也可以按照官网的方法,运行此命令来做。

      echo "0 0,12 * * * root python -c 'import random; import time; time.sleep(random.random() * 3600)' && certbot renew -q" | sudo tee -a /etc/crontab > /dev/null
      
  • 相关阅读:
    零售定价(最终价格计算)(三)
    SAP数据表(一)商品表
    BizTalk 2006 R2 如何实现EDI报文的接收处理
    Simulate a Windows Service using ASP.NET to run scheduled jobs
    看曾士强评胡雪岩
    Smart Client Software Factory 初试
    Asp.net Dynamic Data之四定义字段的显示/编辑模板和自定义验证逻辑
    To set a 64bit mode IIS installation to 32bit mode
    集中日志查询平台方案(Draft)
    .net开发框架比较
  • 原文地址:https://www.cnblogs.com/young233/p/13725371.html
Copyright © 2011-2022 走看看