WordPress建站:Linode VPS上部署SSL启用HTTPS全攻略

2016-12-24发布在 建站7913 次访问

14152514_l

这阵子,外贸圈子里最热的就两个事情:

  1. 从2017年1月1日起,国家税务总局开始清查境外账户(CRS 体系下的非居民账户)
  2. 从2017年1月1日起,谷歌 Chrome 浏览器将会把采用 HTTP 协议的网站标记为“不安全”网站

第1)件事情我们先不论,后面文章再说。先说说第2件事。

Google 一直在推动网站从 HTTP 切换到 HTTPS。可以说,谷歌越来越偏爱安全级别高的网站。2014 年 8 月,Google 将 HTTPS 正式作为排名因素之一。

HTTPS 网站被认为是安全的网站,将会比 HTTP 的网站在排名上获得小幅优势。而在过去的两年中,谷歌对于 HTTPS 网站的网页抓取收录也在明显上升:

google-indexed-pages-in-page1

2014年1月-2016年1月 过去2年中谷歌收录的页面中,HTTPS 网页的收录量已经超过30%

而从谷歌官方人员 John Mueller(谷歌站长趋势分析师)的话中也可以看出来,谷歌会破开一切阻挠推行 HTTPS :

john-mueller

关于更多的信息,我就不列举国外消息了。看图说话吧,从别的网站上截的:

read-this

从2017年1月1日起,谷歌 Chrome 浏览器将会把采用 HTTP 协议的网站标记为“不安全”网站

谷歌官方博客消息原文:https://security.googleblog.com/2016/09/moving-towards-more-secure-web.html


那么问题来了:谷歌会不会也在搜索引擎结果页面中标记 HTTP 网站为不安全网站呢?

答案是:很有可能。

那么我们外贸英文网站应该怎么办呢?HTTPS 的目的是确保交易类网站的安全,保证涉及网站平台账户信息,付款信息以及信用卡等信息不泄露。在SEO方面的作用是在 seo 上获取谷歌的好感,排名能够比 HTTP 网站提升一些,但提升幅度也很小。毕竟影响谷歌排名的因素多达200多个,这并不足以对整体网站排名权重产生根本影响。总体而言,

  • 如果你是 B2C 网站,因为会涉及到商城,购物车,付款和订单信息,在线支付等方面的因素,我认为很有必要启用 HTTPS。
  • 而外贸 b2b 网站更多地只是做个公司展示,产品展示,所以 HTTPS 的意义没有 B2C 网站那么大。但加上一个是可以提升“bigger”,另一方面访客也会觉得安全。
最终结论:HTTPS 是大势所趋,不管是 B2C 还是 B2B 网站,迟早都要启用的。

接着来说怎么给网站从 HTTP 换用 HTTPS。总体来说分为四个步骤:安装 SSL 证书、部署 SSL 证书、修改网站配置文件conf 、网站 URL 中 HTTP 替换为 HTTPS。

一、安装 SSL 证书(Let’s Encrypt)

SSL 证书有免费的也有收费的。具体就不科普了。免费的也可以用,如大名鼎鼎的 Let’s Encrypt SSL certificates.
(2017.6月更新:Let’s Encrypt 已正式更名为 Certbot )

分两种情况吧。鉴于大多数外贸建站的朋友用虚拟主机 Bluehost,也有小部分朋友用 VPS 。那么还是分开说:

在 Bluehost 上安装 Let’s Encrypt 证书有两个小问题: 1)费用问题,看你是否能接受:你买的 Bluehost,5.45美金/月。为了安装证书,必须买独立IP,要再花 $5.99/月(以前才$3.33/月),这就11.44美金/月了。 然后呢,Bluehost 自己也卖付费的 SSL证书,$4.17/月。 你跟他说我不用你们家的付费证书,我要用第三方的免费 Let’s Encrypt 证书, BH 客服肯定不爽,极力推荐你他们自己的付费 SSL证书,在你再三要求之下,极不情愿地帮你配置了免费证书。这都 11.44美金/月了。 如果你觉得用了 BH 的主机和独立IP,也一起用 Bluehost 家的付费证书吧,一劳永逸。那么你就还要掏 $4.17/月。加一起多少了?$15.61/月! 而 Linode VPS 呢?$10/月搞定,还能自己装个FQ 的SS。所以虚拟主机 Bluehost 上用 HTTPS,那费用反而比 VPS 还高。 2017.1月更新:不需要了,感谢 WordPress。WordPress官方要求 Bluehost 尽快提供免费的SSL证书,否则从WP官方推荐的主机商名单中除名。Bluehost 迫于压力,已经推出了免费的SSL证书,无需购买独立IP即可安装(第一个网站免费SSL,第二个网站要加SSL就必须升级到独立主机才可以) 2)网站个数问题:Bluehost 要求每个要加 SSL 证书的网站都得配备独立 IP,而且每个 cPanel 账户只能加一个 IP,所以如果一个账户有几个网站那就尴尬了。

本文主要介绍 VPS 怎样安装部署 SSL 证书并启用 HTTPS。

下载和安装证书

1)先安装 git 包

连接上 VPS 后,在 Xshell 上粘贴命令(每条命令用鼠标右键复制粘贴,回车执行即可。不支持 ctrl+v 粘贴):

sudo yum install git

2)下载证书包

sudo git clone https://github.com/letsencrypt/letsencrypt /opt/letsencrypt
(2017.6月更新:Let's Encrypt 已正式更名为 Certbot )
新的命令为:
sudo git clone https://github.com/certbot/certbot /opt/letsencrypt

3)进入证书目录

cd /opt/letsencrypt

二、创建并部署 Let’s Encrypt SSL 证书

继续命令行执行:

sudo -H ./letsencrypt-auto certonly --standalone -d example.com -d www.example.com
(2017.6月更新:Let's Encrypt 已正式更名为 Certbot )
新的命令为:
./certbot-auto certonly --standalone --email 2897xxx@qq.com -d www.example.com -d example.com

注意:

  • 上面命令中的 email 地址是方便你接收证书密钥回复以及紧急信息的,尽量填写企业邮箱或者 gmail 邮箱,QQ邮箱应该也可以,你可以填写试试。
  • 你的网站域名如果是 xyz.com,那么上面就改为:-d www.xyz.com -d xyz.com

建议先把上面命令复制粘贴到记事本里,把 www.example.comexample.com 先替换好,然后粘贴执行。

然后等待:

waiting

接着,会询问你是否同意的协议。agree 的话,输入 a,回车。此时就准备创建证书了。

注意:如果你之前看过我的 VPS 教程,在 VPS 上安装过 FQ 的 shadowsocks,那么这一步会提示 443 端口被占用,无法继续。由于 SS 是用服务器的 443 端口,而且目前进程默认开启,所以不能继续安装。此时中止安装,回到 Xshell 命令行界面,输入:service shadowsocks stop  然后回车。会停用 shadowsocks,把 443 端口空出来。

stop-ss

如上面截图所示,显示: INFO:loading config from /etc/shadowsocks.json stopped Stopping Shadowsocks success 这表明我们已经关闭了 SS 进程。此时重新粘贴上文蓝色粗体部分的命令(注意 example.com 替换成你的域名),然后回车执行,重新执行安装步骤。

最后成功创建证书。

一般情况下,屏幕显示创建的信息如下:

IMPORTANT NOTES:
- If you lose your account credentials, you can recover them through
  e-mails sent to somebody@example.com.
- Congratulations! Your certificate and chain have been saved at
  /etc/letsencrypt/live/example.com/fullchain.pem. Your
  cert will expire on 2016-03-31. To obtain a new version of the
  certificate in the future, simply run Let's Encrypt again.
- Your account credentials have been saved in your Let's Encrypt
  configuration directory at /etc/letsencrypt. You should make a
  secure backup of this folder now. This configuration directory will
  also contain certificates and private keys obtained by Let's
  Encrypt, so making regular backups of this folder is ideal.
- If you like Let's Encrypt, please consider supporting our work by:

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

此时粘贴执行命令:

sudo ls /etc/letsencrypt/live

会列出该目录下,证书文件存放的网站文件夹,文件夹名就是网站域名。

cer1

注意看一下是主域名还是 www域名。这很重要!一会配置证书路径的时候需要检查一下,保证路径正确!比如,这里显示的是主域名,如图中 pxxxl.com,此时继续粘贴:

sudo ls /etc/letsencrypt/live/pxxxl.com(或可能是www.pxxxl.com)

注意上面 pxxxl.com 替换成你的域名。此时会显示创建了 4 个证书。分别是:

cert.pem
chain.pem
fullchain.pem(公钥)
privkey.pem(私钥)

最后两个是我们要用的,需要写到虚拟主机配置文件 conf 里面。

三、修改网站配置文件

用 XFTP 进入 /usr/local/nginx/conf/vhost/ 下的 你的网站的配置文件,通常是 www.xyz.com.conf 文件。下载下来,用 notepad++ 打开编辑:

CTRL+A 全选中所有代码,删除。然后复制下面我已经配置好的代码,粘贴进入。

server
 {
 listen 80;
 #listen [::]:80;
 server_name www.xyz.com xyz.com;
 return 301 https://www.xyz.com$request_uri;
 }

server
 {
 listen 443 ssl http2;
 ssl_certificate /etc/letsencrypt/live/www.xyz.com/fullchain.pem;
 ssl_certificate_key /etc/letsencrypt/live/www.xyz.com/privkey.pem;
 # 注意检查上面证书的路径,live下的证书文件夹名是否含有www,如果没有,请在上面两行中删除 www.

 ssl_ciphers "EECDH+CHACHA20:EECDH+CHACHA20-draft:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5";
 ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
 ssl_prefer_server_ciphers on;
 ssl_session_cache shared:SSL:10m;

 # HSTS (ngx_http_headers_module is required) (31536000 seconds = 12 months)
 # add_header Strict-Transport-Security "max-age=31536000" always;

 # OCSP Stapling ---
 # fetch OCSP records from URL in ssl_certificate and cache them
 ssl_stapling on;
 ssl_stapling_verify on;

index index.html index.htm index.php default.html default.htm default.php;
 server_name www.xyz.com;
 root /home/wwwroot/www.xyz.com;

include wordpress.conf;
 #error_page 404 /404.html;
 include enable-php.conf;

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
 {
 expires 30d;
 }

location /wp-content/uploads/ {  
location ~ .*\.(php)?$ {  
deny all;  
} 
} 

location ~ .*\.(js|css)?$
 {
 expires 12h;
 }

location ~ /\.
 {
 deny all;
 }
 access_log off;
 }

注意检查一下,把上面所有的 xyz.com 换成你的网站主域名。然后保存。

注意:为了让过程简单一些,我们这先别急着上传覆盖源文件。先别重启 nginx。这一步我们先配置好文件,但先不上传重启 nginx。

 

四、把 WordPress 数据库中 HTTP 替换成 HTTPS

登录 WordPress 后台,然后点击插件,安装插件,搜索:Velvet Blues Update URLs  插件,启用。

启用之后,按照图中设置,

replace

点击 Update 按钮。之后在上方会显示进行了哪些替换处理的结果:

replace2

然后,检查一下:

设置(Setting)-常规(General) 那里,WordPress地址 和 网站地址(Site URL) 是不是都改成 https 了。如:https://www.xyz.com

如果还是 http,请手动修改一下。修改之后,系统会立即把你登出后台。

五、上传网站配置文件,重启 nginx

上传第三步我们保存的 www.xyz.com.conf 覆盖掉原文件,

接着 Xshell 执行:service nginx restart

OK,此时 访问你的网站,会自动跳转到 https。

OK,此时再访问首页,已经是绿色小锁加持了!

finished

 

finished-1

 

finishedp-2

 

finished-3

六、我都做了,为什么看不到小绿锁?

可能有些人完成第五步后,发现 chrome 浏览器 https 左边并没有出现绿色的小锁啊?

说说两种情况:

如果你是新装 WordPress,这一步必显示绿色小锁。

如果你是网站搬家,把之前的网站搬过来的,那么可能会不显示小锁。如果你每一步都做好了,但是还是不显示小绿锁,那么只能说,你的数据库中调用的资源虽然都是 https 的,但是页面存在仍用 http 调用的资源。最常见的可能是:

某个主题的 banner图片,你在 主题设置 里面填写的某个资源(多数是图片) 的URL 地址是死的,并不会被存入数据库,所以用插件替换不掉。比如:http:www.xyz.com/wp-content/upload/2016/xx/xxxx.jpg

类似这样在主题设置里写死的 URL 里的 http,插件是没有办法替换到的。所以你要自己去检查是否有调用 https:// 的资源。把这些改成 https:// 就会正常出现小绿锁了。

怎么检查呢?

用浏览器的 F12(科学点的浏览器,如 chrome, firefox … 搜狗高速模式也OK,360我不用所以不知道,IE是铁定不行)。

按 F12 后弹出的工具界面 tab 里选择 network,会列出加载的网络资源。注意这时候是空的,因为页面已经加载完毕了。

resource-examination

你需要再按一下 F5刷新页面,这个时候会出现加载的资源列表。把鼠标移动到这些资源的 URL 那里会自动显示出资源 URL 地址。一个个检查哪个是 http 的,然后想办法改掉就OK了!

七、关于免费的 Let’s Encrypt SSL 证书的说明

免费的 L et’s Encrypt SSL certificates 的有效期一般是 90天,90天之后可以再续期。也不麻烦,执行命令行即可。

八、可以让证书到期自动续期吗?

可以!利用 cron 可以让证书到期自动续期。

关于自动续期,建议看看这篇文章:Cron自动续期命令失效导致网站SSL证书到期的解决方案

九、测试 SSL 是否完全OK

感谢 @tudou 提供的测试网址:

https://www.ssllabs.com/ssltest/

测试结果:A+  完美~!

get-score

十、为什么我的测试结果是 A,不是 A+?

没关系,A已经够了!写这篇文章之前,我配置 SSL 的 nginx 规则代码(本文第三部分)里是含有 HSTS (HTTP Strict Transport Security) 协议的。至于什么是 HSTS 协议,你可以自行百度。

如果你的 SSL 规则里添加了 HSTS协议,那么它起到的主要作用是 强制用户的浏览器只能用 https 来访问你的网站。所以得分一定高:A+。上面截图也是基于之前的 https 配置。

但是,根据我数次试验,HSTS 是个双刃剑,一旦你启用了,想取消特别特别麻烦。所以我后来在文章中把那个代码注释掉了。大家可以无视,其实得分 A 也够了!

如果你特别在意得分,觉得网站也一直会使用https下去,那么就在第三部份的网站配置代码中 443 Server 段内,找到以下这两行代码:

 # HSTS (ngx_http_headers_module is required) (31536000 seconds = 12 months)
 # add_header Strict-Transport-Security "max-age=31536000" always;

HSTS 要求 max-age 最少为6个月,即 15768000,最好为12个月。

把上面第 2 行里的 add_header 前面的 # 号去掉,保存覆盖重启 nginx 即可启用 HSTS。再测试得分,就是A+。

但,我还是建议不要单纯为了锦上添花的分数给自己麻烦。一旦加了 HSTS 之后,想取消很麻烦。以后你如果想临时停用 https,网站是无法访问的。因为你网站临时恢复成 http,但 HSTS 强制了所有访问者的浏览器在 12 个月内只能用 https 来访问,于是就会访问出错。因此,建议如果以后需要,再加上这条。

关于 HSTS 的用法其实还有更细节的内容,比如,如果对子域名也同样执行 HSTS,则规则为:

add_header Strict-Transport-Security "max-age=31536000; includeSubDomains" always;

还有是否创建 preload list 等等……

这里不想介绍那么多,因为并不建议设置 HSTS,所以这里就不再多说了,有需要请自行百度。

十一、有两个网站,怎么给第二个网站配置 https?

进入证书目录

cd /opt/letsencrypt

粘贴一下命令,回车执行:

sudo -H ./letsencrypt-auto certonly --standalone -d second.com -d www.second.com

此时,会提示你端口443已经占用,无法安装证书。

由于我们第一个网站的 https 已经占用了443 端口,所以我们要先把 443 端口进程关闭。一般是因为当前网站 nginx 占用了 80 和 443 两个端口。所以我们先执行:

service nginx stop

如果停止成功,则重新粘贴上面那条 sudo 命令来安装证书

如果停止不成功,则执行 netstat -apn 来看看具体的 nginx 的 PID(进程号)

stop-pid-tips

观察一下 443 端口的 nginx 进程号(不一定是26212)。然后先后执行两个命令:

kill -9 进程号

service nginx stop

停止 nginx 之后,接着粘贴上面那条 sudo 的命令,即可正常给第二个网站安装证书。安装完证书,继续执行自动续期命令。完成之后,记得重启 nginx!

service nginx restart

安装好证书后,再从第三步开始配置网站 conf 文件。三、四、五、八。


本文完!

 

分享到微信朋友圈

LiaoSam
LiaoSam
外贸综合症患者

68条评论

发表我的评论

取消评论

邮箱白名单说明:最近料网自动提醒邮件经常会被一些邮件服务商拦截。为了您顺利并及时地收取留言被回复的提醒邮件,请在您邮箱中把料网 liaosam.com 加入白名单域名。

已读说明
设为私密评论
添加表情

Hi,您需要填写昵称和邮箱!

您的邮箱地址不会公开,仅仅用于收取回复。建议填写QQ邮箱,不宜填写工作邮箱。
  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址 (没有就留空)
呃,评论有点多呢... 料网小秘书为您玩命加载中...
  1. #22
    Brent

    请教SAM老师,我在同一个IP下的VPS安装证书,第一个网站完美有小绿锁. 访问正常.
    按照教程安装第二个的时候也OK了, 问题是,第一个不能访问了.
    chrome提醒您的连接不是私密连接,https不能访问了,不知应该如何处理?谢谢.

    7小时前回复
  2. #21
    anne

    该评论为私密评论

    1个月前 (06-14)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @anne 该评论为私密评论
      1个月前 (06-14)回复
      • anne

        @Liaosam 该评论为私密评论

        1个月前 (06-14)回复
        • LiaoSam
          LiaoSam,外贸综合症患者。
          @anne OK了。出错的原因是 nginx www.xyz.com.conf 配置文件里证书的路径是: /etc/letsencrypt/live/www.xyz.com/fullchain.pem,而实际证书在 XFTP 中可以看到 /etc/letsencrypt/live/下的文件夹目录名是 xyz.com,不是 www.xyz.com,因此把配置文件里的 www. 去掉重启了nginx就可以了。
          1个月前 (06-14)回复
          • anne

            @LiaoSam 该评论为私密评论

            1个月前 (06-14)回复
            • LiaoSam
              Liaosam,外贸综合症患者。
              @anne 该评论为私密评论
              1个月前 (06-14)回复
              • anne

                @Liaosam 该评论为私密评论

                1个月前 (06-14)回复
                • LiaoSam
                  Liaosam,外贸综合症患者。
                  @anne 只是更名了,不需要重新下载安装。没有什么影响的。
                  1个月前 (06-14)回复
                • anne

                  @anne 该评论为私密评论

                  1个月前 (06-14)回复
  3. #20
    zzu

    请教一下,如果把网站改为https的话,会不会对已经收录的页面产生负面影响呢,毕竟网址从http://***.com 变成了https://***.com , 从而影响google的权重排名呢

    1个月前 (06-12)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @zzu 这个问题 SEOMOZ 的创始人 Rand 曾专门写过一篇文章说明:短期会有影响,排名会有所下滑。但如果能坚持更新和优化,6个月内排名会恢复并且较之以前有所提升。
      1个月前 (06-12)回复
  4. #19
    Jeff

    该评论为私密评论

    1个月前 (06-10)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @Jeff 该评论为私密评论
      1个月前 (06-14)回复
  5. #18
    Coo

    料神,请问一下,安装完毕后,前台访问没有问题,但是访问后台就显示重定向的次数过多,一直没办法登陆.

    并且输入service nginx restart的时候,显示如下:

    Stoping nginx… nginx: [emerg] BIO_new_file(“/etc/letsencrypt/live/www.xyz.com/fullchain.pem”) failed (SSL: error:02001002:system library:fopen:No such file or directory:fopen(‘/etc/letsencrypt/live/www.xyz.com/fullchain.pem’,’r’) error:2006D080:BIO routines:BIO_new_file:no such file)
    failed. Use force-quit
    Starting nginx… nginx (pid 32361 32360) already running.

    请问料神,现在该怎么办呢,已经折腾了一天了,都还没折腾出来,拜托料大了.

    2个月前 (06-06)回复
    • alexchen88

      @Coo 遇到同样的问题,把网站配置文件中/etc/letsencrypt/live/www.xyz.com/ 的www 去掉, 再service nginx restart 即可

      1个月前 (06-08)回复
  6. #17
    winnings

    料神,安装Velvet Blues Update URLs弹出Connection Information,要求输入Host Name 和FTP账号密码,怎么办啊?我当时选装的是CentOS7。

    2个月前 (05-26)回复
    • winnings

      @winnings 已经搞定了,我跳过了一个步骤。谢谢!

      2个月前 (05-26)回复
  7. #16
    Leo2514

    大神,你修改网站配置文件 里面的目录好像搞错了。 因为xyz.com是主域名,所以应该是这样 root /home/wwwroot/xyz.com。 你上面写的是 root /home/wwwroot/www.xyz.com, 不知道我对不对?

    2个月前 (05-23)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @Leo2514 这里跟主域名还是子域名没什么关系。root /home/wwwroot/www.xyz.com 这个 www.xyz.com 是网站文件的目录,并不是什么主域名。
      看来你没明白创建网站 (vhost) 的流程以及配置文件 root 的含义。
      创建 vhost 的时候(lnmp vhost add),会让你你填写网站域名,一般很多人习惯用 www.xyz.com 的域名,脚本会同时创建同域名的网站文件目录,文件夹名为 www.xyz.com,位置为:/home/wwwroot/www.xyz.com。并且会问你是否还要添加其他域名,这时一般再添加主域名 xyz.com。
      如果你偏向于网站域名不带 www,那么流程就反过来,你填写主域名,让你补充时你再填写 www 域名,这时配置文件里定义网站文件的路径就不带 www。
      2个月前 (05-23)回复
      • Leo2514

        @Liaosam OK,明白了。

        2个月前 (05-23)回复
      • Leo2514

        @Liaosam 对了,大神我这种刚刚安装wordpress 还没有开始使用主题 和完善内容的网站,是不是要暂时性 禁止蜘蛛抓取?

        2个月前 (05-23)回复
        • LiaoSam
          Liaosam,外贸综合症患者。
          @Leo2514 暂时禁止蜘蛛抓取,等网站内容丰富起来再开放。如果是博客类、文章站,一般都是等至少有了十篇左右一定质量的文章时才开发给蜘蛛抓取。
          2个月前 (05-23)回复
  8. #15
    Sophia

    请教料神,在第二步的时候遇到下面这个error,该如何处理啊?
    IMPORTANT NOTES:
    – The following errors were reported by the server:

    Domain: example.com
    Type: malformed
    Detail: No available addresses for getTLSSNICerts to dial

    To fix these errors, please make sure that you did not provide any
    invalid information to the client, and try running Certbot again.

    2个月前 (05-23)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @Sophia 该域名必须解析到当前的VPS的 IP 上(证书程序要验证域名所有权),否则可能会有这类的错误。
      2个月前 (05-23)回复
      • Sophia

        @Liaosam 域名是在bluehost上面买的,已经解析到linode上了,不知道有什么办法可以验证是否解析正确?

        2个月前 (05-23)回复
  9. #14
    yangyang

    请教料神老师, 运行第二步的时候,出现以下错误,该如何更正错误啊
    Failed authorization procedure. mydomain.com (tls-sni-01): urn:acme:error:connection :: The server could not connect to the client to verify the domain :: DNS problem: SERVFAIL looking up A for mydomain.com

    IMPORTANT NOTES:
    – The following errors were reported by the server:

    Domain: mydomain.com
    Type: connection
    Detail: DNS problem: SERVFAIL looking up A for mydomain.com

    To fix these errors, please make sure that your domain name was
    entered correctly and the DNS A record(s) for that domain
    contain(s) the right IP address. Additionally, please check that
    your computer has a publicly routable IP address and that no
    firewalls are preventing the server from communicating with the
    client. If you’re using the webroot plugin, you should also verify
    that you are serving files from the webroot path you provided.

    2个月前 (05-18)回复
    • 猫咪

      @yangyang 同遇到该问题,还在纠结中。
      请问你解决了吗? :grin:

      1个月前 (06-09)回复
  10. #13
    vychannel

    该评论为私密评论

    3个月前 (04-20)回复
  11. #12

    该评论为私密评论

    3个月前 (04-18)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @蒋明 不知道你那边具体什么情况,所以无法分析出来原因。我觉得提问之前要换位思考一下,花半分钟写的笼统的提问,不能期待别人花半小时耐心地问你版本和操作步骤,模拟出你的环境来帮你分析解决。
      3个月前 (04-18)回复
      • @Liaosam 该评论为私密评论

        3个月前 (04-20)回复
        • LiaoSam
          Liaosam,外贸综合症患者。
          @蒋明 该评论为私密评论
          3个月前 (04-20)回复
          • @Liaosam 好的,我知道了。谢谢你料神老师

            3个月前 (04-20)回复
  12. #11
    mrshu

    该评论为私密评论

    4个月前 (04-07)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @mrshu 这并不能说明无效吧?看提示文字是说已经有 let’s encrypt 的文件目录了。
      3个月前 (04-18)回复
  13. #10
    风声

    let’s encrypt已经有简化版本的更新bash, 楼主记得更新corn对应的脚本了.

    4个月前 (03-21)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @风声 谢谢提醒!我已自己写了cron命令,更新过了。
      3个月前 (04-18)回复
  14. #9
    James

    料神,首先,感谢您,让我这个小白能弄明白ssl证书,我的第一个站非常完美的实现了小绿锁,非常感谢。
    请教您一下,在我按照您的方法部署第二个站的时候,最后跳转https域名.com 后出现了404 Not Found nginx 网站就打不开了。我不知道这个怎么解决,对了,我是在linode 的5美元vps上建的两个wordpress站。第一个没有任何问题,第二个全部署完后就404 Not Found nginx了。求料神帮助。

    5个月前 (02-17)回复
    • james

      @James 三、在代码中
      index index.html index.htm index.php default.html default.htm default.php;
      server_name www.xyz.com xyz.com;
      root /home/wwwroot/www.xyz.com; (此处是网站文件夹名字,不一定是域名。)
      虽然问题比较小白,但希望和我一样啥也不懂的人注意一下。

      5个月前 (02-19)回复
      • LiaoSam
        Liaosam,外贸综合症患者。
        @james 你之前在WP后台做过 http替换https了吗?
        5个月前 (02-20)回复
    • neo

      @James 该评论为私密评论

      3周前 (06-28)回复
  15. #8
    dave

    料神,请教下,运行到第二步时并没有弹出让输入email,而是出现如下:
    sudo -H ./letsencrypt-auto certonly –standalone -d ***.com -d www.***.com
    Bootstrapping dependencies for RedHat-based OSes…
    yum is /usr/bin/yum
    Loaded plugins: fastestmirror, security
    Setting up Install Process
    Loading mirror speeds from cached hostfile
    * epel: mirrors.xmission.com
    Package gcc-4.4.7-17.el6.x86_64 already installed and latest version
    Package dialog-1.1-9.20080819.1.el6.x86_64 already installed and latest version
    Package augeas-libs-1.0.0-10.el6.x86_64 already installed and latest version
    Package openssl-1.0.1e-48.el6_8.3.x86_64 already installed and latest version
    Package openssl-devel-1.0.1e-48.el6_8.3.x86_64 already installed and latest version
    Package libffi-devel-3.0.5-3.2.el6.x86_64 already installed and latest version
    Package redhat-rpm-config-9.0.3-51.el6.centos.noarch already installed and latest version
    Package ca-certificates-2015.2.6-65.0.1.el6_7.noarch already installed and latest version
    Package python-2.6.6-66.el6_8.x86_64 already installed and latest version
    Package python-devel-2.6.6-66.el6_8.x86_64 already installed and latest version
    Package python-virtualenv-1.10.1-1.el6.noarch already installed and latest version
    Package python-tools-2.6.6-66.el6_8.x86_64 already installed and latest version
    Package python-pip-7.1.0-1.el6.noarch already installed and latest version
    Nothing to do
    Creating virtual environment…
    Traceback (most recent call last):
    File “/usr/bin/virtualenv”, line 2, in
    import virtualenv
    ImportError: No module named virtualenv
    请问是什么问题?

    6个月前 (01-09)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @dave 你安装的是 CentOs 哪个版本? CentOS 7?
      6个月前 (01-09)回复
      • dave

        @Liaosam Centos 6.8

        6个月前 (01-09)回复
        • LiaoSam
          Liaosam,外贸综合症患者。
          @dave 可能 python 的问题。你可以参考这两篇文章:
          No module named virtualenv:
          https://www.a8z8.com/html/2016/tech_0707/507.html
          https://www.a8z8.com/html/2016/tech_0707/506.html
          6个月前 (01-09)回复
  16. #7
    helloworld678

    料神,为第二个网站安装SSL,还需要重新下载和安装证书吗?还是从“创建并部署 Let’s Encrypt SSL 证书”这一步开始呢?

    7个月前 (01-07)回复
    • LiaoSam
      LiaoSam,外贸综合症患者。
      @helloworld678 不需要重新下载,从第二步创建并部署 Let’s Encrypt SSL 证书开始就可以了。多网站安装证书,证书会自动进行域名所属识别并且创建时会按不同域名存放在不同的目录下。
      7个月前 (01-07)回复
      • helloworld678

        @LiaoSam Sam,我没有建shadowshocks,但是出现了以下内容:
        Port 443 is already in use by another process. This will prevent us from binding to that port. Please stop the process that is populating the port in question and try again.

        Saving debug log to /var/log/letsencrypt/letsencrypt.log
        Starting new HTTPS connection (1): acme-v01.api.letsencrypt.org
        Obtaining a new certificate
        Performing the following challenges:
        tls-sni-01 challenge for xxx.com
        tls-sni-01 challenge for www.xxx.com
        Cleaning up challenges

        7个月前 (01-07)回复
        • LiaoSam
          Liaosam,外贸综合症患者。
          @helloworld678 你是两个网站都在一个VPS上吧?因为你第一个网站开启了SSL占用了443端口。解决的办法有两个:

          1)先把第一个网站的配置文件 .conf 改回去之前的配置,把关于443端口侦听和SSL之类的配置删除,用系统之前默认的配置。然后重启 nginx 和 lnmp 再重新执行证书安装。

          2)强行 kill 443 进程。执行 netstat -apn 命令:

          查看当前占用 443 端口的 nginx 的进程 PID。看顶部最上面一行右上角,有个 PID/Program name
          然后找到 443 端口 nginx 的进程数字,如 23220/nginx

          此时执行:kill -9 23220,回车。
          然后重启 nginx:service nginx restart

          7个月前 (01-07)回复
          • helloworld678

            @Liaosam 该评论为私密评论

            6个月前 (01-08)回复
          • Steven

            @Liaosam 该评论为私密评论

            6个月前 (01-10)回复
            • LiaoSam
              Liaosam,外贸综合症患者。
              @Steven 更新了一下文章,建议再看看。
              6个月前 (01-19)回复
  17. #6
    Brent

    谢谢sam,在您的这篇文章的指导下,一步步成功了。
    另外提醒一下以后的同学,若是遇到下面的这个问题,可以关闭防火墙就可以了。
    Failed to connect to XXX.XXX.XXX.XXX:443 for TLS-SNI-01
    challenge

    另外报告一下:我到第三部结束之后,就看到小锁了。

    7个月前 (01-05)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @Brent 不客气。怎么还有防火墙?你用的什么 VPS?
      6个月前 (01-08)回复
      • Brent

        @Liaosam 我用的是CentOS 6

        6个月前 (01-09)回复
      • Brent

        @Liaosam vultr

        6个月前 (01-09)回复
        • LiaoSam
          Liaosam,外贸综合症患者。
          @Brent Vultr 有个问题,5美金方案的内存才 768MB,10美金的内存也才 1G,而 Linode 10美金 2G内存。你如果要用 avada 那种特别吃内存的 WP主题,那么 vultr 不如 linode.
          6个月前 (01-12)回复
          • Brent

            @Liaosam 感谢料神回复,我现在用vultr,若是改用linode,SSL证书是不是要重新安装一遍呀?

            6个月前 (01-13)回复
            • LiaoSam
              Liaosam,外贸综合症患者。
              @Brent 是的。安装证书的时候会验证域名所有权,所以你改用 linode 之后,你的vps服务器 IP 就变了。所以你需要重新做 A记录解析,成功后再去安装证书,证书安装过程中会验证域名是否解析在当前vps服务器的 IP 上。你重新做过了解析就会顺利安装。
              6个月前 (01-13)回复
  18. #5
    ve

    SSL后http改成了HTTP, webmaster 和 GA、adwords应该怎么处理网址的问题?

    7个月前 (01-01)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @ve 没有什么影响。http 做了重定向了,蜘蛛也会爬 https 的。其他的能修改就修改下,改不了也不要紧。
      7个月前 (01-01)回复
  19. #4

    HTTPS今年确实火了

    7个月前 (12-28)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @刘荣焕 该评论为私密评论
      6个月前 (01-19)回复
  20. #3

    该评论为私密评论

    7个月前 (12-27)回复
  21. #2
    Jack

    今天刚买了3年BH空间就碰到SSL这个问题,$15.61/月确实贵了点,看来只有HTTP先用着,3年后确实有必要再转到Linode。SAM,这样可以吗?毕竟就是一个B2B网站,像我们这种内容不多的站做GG自然排名也很难做到前几页的。

    7个月前 (12-26)回复
  22. #1

    新鲜出炉的呢!
    部署完成后记得去 https://www.ssllabs.com/ssltest/ 测试下~~

    7个月前 (12-24)回复
    • LiaoSam
      Liaosam,外贸综合症患者。
      @homu 谢谢测试地址!已更到文章里:)
      7个月前 (12-24)回复
  1. A Thousand Year Christina_Perri
  2. And the winner is Gerard Darmon