nginx開啟https
使用Letsencrypt為域名申請免費證書,不是泛域名的方式,是單域名或者多域名方式,會有多個公鑰跟私鑰
使用standalone方式獲取證書
安裝letsencrypt
git clone https://github.com/letsencrypt/letsencrypt
進入目錄
cd letsencrypt
執行命令獲取證書,注意用standalone方式獲取證書,需要關閉服務器的80端口,因為會占用這個端口
--email制定證書過期通知郵件,-d制定要為那個域名申請證書,可以通過-d指定多域名
注意,指定的域名必須可以查到a記錄,在域名供應商那邊有綁定固定IP
./letsencrypt-auto certonly --standalone --email xxx@qq.com -d www.xxx.com
生成的證書公鑰,私鑰在/etc/letsencrypt/live里面,以域名為名字的目錄
修改nginx的配置文件,啟用ssl證書驗證
server { listen 443 ssl; server_name 填入域名 ; error_log logs/apple_app_error.log error; access_log logs/apple_access.log main; ssl on; #指定證書公鑰 ssl_certificate /etc/letsencrypt/live/app.blockmango.net/fullchain.pem; #指定證書私鑰 ssl_certificate_key /etc/letsencrypt/live/app.blockmango.net/privkey.pem; ssl_session_timeout 5m; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # ssl_protocols SSLv3 TLSv1; # ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv3:+EXP; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4; ssl_prefer_server_ciphers on; location /apple-app-site-association { default_type application/json; expires 1d; } location / { root html; index index.html index.htm; expires 1d; } #error_page 404 /404.html; #redirect server error pages to the static page /50x.html # error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }
重啟nginx服務即可
注意通過免費的方式申請的證書,只有三個月有效期,三個月后要為過期的證書更新
還有使用standalone這種方式申請或者更新的,操作前都需要關閉http服務,更新后再打開http服務
還有一種方式比較好用的,是webroot,但是這種方式需要在改服務器還沒有申請過證書前,即nginx的配置文件沒修改成ssl模式前使用
因為本次對服務器申請證書,是之前已經有過其他域名證書申請了,且是用standalone方式申請的,現在改為webroot的話有點麻煩,所以繼續使用standalone方式為新域名申請證書
當然這樣的話,就必須維護多個證書
參考鏈接:https://blog.csdn.net/dancen/article/details/81311688