nginx上配置https的條件:
1、SSL證書和服務器私鑰文件
2、nginx支持SSL模塊
一、獲取SSL證書
網上有提供權威認證的SSL證書的網站,但多數是收費的,而且不便宜。在正式的生產環境中,強烈不建議使用免費的SSL證書,但我們這次只是用於測試,所以決定使用下免費的SSL證書。
下面介紹幾個免費的SSL證書提供商:(以下內容非原創)
- CloudFlare SSL:CloudFlare是美國一家提供CDN服務的網站,在世界各地都有自己的CDN服務器節點,國內外很多大型公司或者網站都在使用 CloudFlare的CDN服務(百度雲cdn加速在海外用的就是CloudFlare的CDN節點),當然國內站長最常用的就是CloudFlare的免費CDN,加速也很好。CloudFlare提供的免費SSL證書是UniversalSSL,即通用SSL,用戶無需向證書發放機構申請和配置證書就可以使用的SSL證書,CloudFlare向所有用戶(包括免費用戶)提供SSL加密功能,web界面5分鍾內就設置好證書,24小時內完成自動部署,為網站的流量提供基於橢圓曲線數字簽名算法(ECDSA)的TLS加密服務。
- Wosign沃通SSL:Wosign沃通是國內一家提供SSL證書服務的網站,其免費的SSL證書申請比較簡單,在線開通,一個SSL證書只能對應一個域名(單一域名,非通配域名),支持證書狀態在線查詢協議(OCSP)。
- StartSSL:StartSSL是StartCom公司旗下的SSL證書,提供免費SSL證書服務,且StartSSL被包括Chrome、Firefox、IE 在內的主流瀏覽器支持,幾乎所有的主流瀏覽器都可以正常識別StartSSL,任何個人都可以從StartSSL中申請到免費一年的SSL證書。
- NameCheap:NameCheap是一家領先的ICANN認可的域名注冊和網站托管公司,成立於2000年。該公司提供免費DNS解析,網址轉發(可隱藏原URL,支持301重定向)等服務。此外,NameCheap還提供了一年的SSL證書免費服務。
- CloudFlare SSL和Wosign沃通SSL申請開通和安裝使用:https://www.freehao123.com/cloudflare-wosign-ssl/
- StartSSL申請:https://www.freehao123.com/startssl-ssl/
- 在Nginx上配置NameCheap免費SSL:http://linux.it.net.cn/CentOS/course/2014/0318/520.html
需要兩個文件:
SSL證書:.crt
私鑰文件:.key
二、在nginx上配置支持SSL
1、檢查nginx是否安裝了SSL模塊
# nginx -V
configure arguments: --prefix=/usr/local/nginx --with-http_sysguard_module --with-http_realip_module
這個nginx是編譯安裝的,編譯時沒有指定安裝SSLL模塊,需要重新編譯,加上 --with-http_ssl_module
另外,nginx需要openssl提供ssl支持,也需要檢查是否已經安裝了openssl。
nginx重編譯的步驟:
1)找到安裝nginx的源碼根目錄,並查看原編譯參數。
# cd /root/tengine-1.5.2
# nginx -V
configure arguments: --prefix=/usr/local/nginx --with-http_sysguard_module --with-http_realip_module
2)重新編譯nginx
#./configure --prefix=/usr/local/nginx --with-http_sysguard_module --with-http_realip_module --with-http_ssl_module
# make
注意:千萬不要 make install ,否則就會覆蓋安裝了。
make 后,在源碼根目錄的objs目錄中多了一個nginx程序,就是新編譯的nginx程序。
3)備份舊的nginx程序
# cp -a /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.bak
4)用新的nginx程序覆蓋舊的
# cp -a objs/nginx /usr/local/nginx/sbin/nginx
5)測試新nginx程序是否正確
# nginx -t the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok configuration file /usr/local/nginx/conf/nginx.conf test is successful
6)平滑升級
# nginx -s reload
2、配置nginx server支持ssl
1)上傳SSL證書文件和私鑰文件到服務器
這里我們統一放到:/usr/local/nginx/conf/ssl 目錄
# ls /usr/local/nginx/conf/ssl/ ca.crt private.key
2)在特定的server中配置SSL支持
listen 443; server_name xxx.xxx.com; # 開啟ssl支持
ssl on;
# SSL 證書 ssl_certificate /usr/local/nginx/conf/ssl/ca.crt;
# 私鑰文件 ssl_certificate_key /usr/local/nginx/conf/ssl/private.key;
3)重啟nginx服務
# nginx -t
# nginx -s reload
4) 開放防火牆的 443 端口
5)web訪問,檢查https是否能用

常見的異常:
- 提示類似這樣錯誤,說明證書配置有問題:
[emerg] 21482#0: PEM_read_bio_X509_AUX("/usr/local/nginx/conf/ssl/ca.crt") failed (SSL: error:0906D06C:PEM routines:PEM_read_bio:no start line:Expecting: TRUSTED CERTIFICATE)
- 提示類似這樣的錯誤,說明key有問題:
[emerg] SSL_CTX_use_PrivateKey_file("/usr/local/nginx/conf/ssl/private.key") failed (SSL: error:0906D06C:PEM routines:PEM_read_bio:no start line:Expecting: ANY PRIVATE KEY error:140B0009:SSL routines:SSL_CTX_use_PrivateKey_file:PEM lib)
