詳解Nginx服務(wù)器中配置全站HTTPS安全連接的方法
HTTPS就等于HTTP加上TLS(SSL),HTTPS協(xié)議的目標(biāo)主要有三個(gè):
數(shù)據(jù)保密性。保證內(nèi)容在傳輸過程中不會(huì)被第三方查看到。就像快遞員傳遞包裹時(shí)都進(jìn)行了封裝,別人無法知道里面裝了什么東西。
數(shù)據(jù)完整性。及時(shí)發(fā)現(xiàn)被第三方篡改的傳輸內(nèi)容。就像快遞員雖然不知道包裹里裝了什么東西,但他有可能中途掉包,數(shù)據(jù)完整性就是指如果被掉包,我們能輕松發(fā)現(xiàn)并拒收。
身份校驗(yàn)。保證數(shù)據(jù)到達(dá)用戶期望的目的地。就像我們郵寄包裹時(shí),雖然是一個(gè)封裝好的未掉包的包裹,但必須確定這個(gè)包裹不會(huì)送錯(cuò)地方。
啟用HTTPS之前需要有證書,而證書需要首先在自己服務(wù)器上創(chuàng)建CSR,對(duì)應(yīng)的公鑰和私鑰。這里我全部都拿Nginx服務(wù)器舉例,Apache也不會(huì)差太多,都是基于openssl的。因?yàn)槲抑挥幸粋€(gè)主機(jī)域名chabaoo.cn,所以證書方便選擇了COMODO的PositiveSSL,每年9刀。需要注意COMODO要求證書至少是2048位,見下面的命令。激活證書的時(shí)候需要注意common name那里要填寫自己的域名地址,我因?yàn)椴⒉皇褂胘b51.net,所以這里寫的就是chabaoo.cn,需要注意這兩個(gè)主機(jī)地址是不同的。其他的組織名公司名什么的如果沒有就寫NA,不要留空。下面簡(jiǎn)單說一下步驟
1、以root登錄,升級(jí)服務(wù)器。這里是為了解決OpenSSL的一個(gè)大漏洞CVE-2014-0224,因?yàn)镃hangeCipherSpec消息的問題可能導(dǎo)致中間人攻擊,解密并修改被攻擊的服務(wù)器和客戶端之間的通信,從而獲得加密的數(shù)據(jù)。
查看OpenSSL版本,確認(rèn)至少在1.0.1h以上,
openssl version -a
如果沒有,升級(jí)服務(wù)器,以Debian為例
apt-get update apt-get upgrade
2、創(chuàng)建CSR和私鑰
openssl req -new -newkey rsa:2048 -nodes -keyout chabaoo.cn.key -out chabaoo.cn.csr
得到2個(gè)文件,私鑰chabaoo.cn.key,CSR文件chabaoo.cn.csr,其中CSR里面的內(nèi)容在激活證書的時(shí)候需要提交
3、購買證書,完成激活,下載證書文件
下載的證書文件通常是一個(gè)壓縮包,有些是2個(gè)文件,有些是4個(gè)文件
如果是2個(gè)文件,是這樣的:
- www_jb51_net.ca-bundle
- www_jb51_net.crt
如果是4個(gè)文件,通常都是這樣的:
- www_jb51_net.crt
- COMODORSADomainValidationSecureServerCA.crt
- COMODORSAAddTrustCA.crt
- AddTrustExternalCARoot.crt
其中www_slyar_com.ca-bundle就是自動(dòng)合并了其他3個(gè)文件的產(chǎn)物,一個(gè)道理
4、合并證書,順序一定不能錯(cuò)
cat www_jb51_net.crt www_slyar_com.ca-bundle > chabaoo.cn.crt
或者
cat www_slyar_com.crt www_slyar_com.ca-bundle > chabaoo.cn.crt
最后產(chǎn)生的chabaoo.cn.crt是4個(gè)文件的合并,此文件與之前產(chǎn)生的chabaoo.cn.key一起組成了Nginx需要使用的證書
5、把chabaoo.cn.crt和chabaoo.cn.key復(fù)制到Nginx的conf目錄下,比如/usr/local/nginx/conf/
cp chabaoo.cn.crt chabaoo.cn.key /usr/local/nginx/conf/
6、修改Nginx配置文件或者vhost/下的虛擬主機(jī)配置文件,啟用https,配置加密方式等
#合并80和443配置文件也可以,一起配置,最后強(qiáng)制轉(zhuǎn)移80到443就可以了 listen 80; listen 443; #指定證書文件 ssl_certificate chabaoo.cn.crt; ssl_certificate_key chabaoo.cn.key; #禁用不安全的SSLv1 2 3,只使用TLS ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_prefer_server_ciphers on; #RC4也是不安全的了,只能去掉 ssl_ciphers EECDH+CHACHA20:EECDH+AES128:RSA+AES128:EECDH+AES256:RSA+AES256:EECDH+3DES:RSA+3DES:!MD5; #301轉(zhuǎn)移 if ($server_port = 80) { return 301 https://$server_name$request_uri; }
7、測(cè)試Nginx配置文件并重新reload配置文件
Nginx -t service nginx reload
這樣服務(wù)器的HTTPS就配置完了。
既然HTTPS非常安全,數(shù)字證書費(fèi)用也不高,那為什么互聯(lián)網(wǎng)公司不全部使用HTTPS呢?原因主要有兩點(diǎn):
HTTPS對(duì)速度的影響非常明顯。每個(gè)HTTPS連接一般會(huì)增加1-3個(gè)RTT,加上加解密對(duì)性能的消耗,延時(shí)還有可能再增加幾十毫秒。
HTTPS對(duì)CPU計(jì)算能力的消耗很嚴(yán)重,完全握手時(shí),web server的處理能力會(huì)降低至HTTP的10%甚至以下。
HTTPS為什么會(huì)嚴(yán)重降低性能?主要是握手階段時(shí)的大數(shù)運(yùn)算。其中最消耗性能的又是密鑰交換時(shí)的私鑰解密階段(函數(shù)是rsa_private_decryption)。這個(gè)階段的性能消耗占整個(gè)SSL握手性能消耗的95%。
然而隨著各大網(wǎng)站的相繼跟進(jìn)與硬件的摩爾定律下,為了安全而做這點(diǎn)性能犧牲還是值得的。
- Nginx實(shí)現(xiàn)根據(jù)域名http、https分發(fā)配置示例
- Nginx配置多個(gè)HTTPS域名的方法
- 詳解Nginx配置SSL證書實(shí)現(xiàn)Https訪問
- Nginx配置https的實(shí)現(xiàn)
- nginx配置SSL證書實(shí)現(xiàn)https服務(wù)的方法
- Nginx配置SSL證書部署HTTPS網(wǎng)站的方法(頒發(fā)證書)
- 詳解nginx如何配置HTTPS
- nginx配置ssl證書實(shí)現(xiàn)https訪問的示例
- nginx配置ssl實(shí)現(xiàn)https訪問的步驟(適合新手)
- Nginx同時(shí)支持Http和Https的配置詳解
- nginx開啟https配置之后網(wǎng)頁無法訪問的問題處理解決
相關(guān)文章
Windows下用Nginx配置https服務(wù)器及反向代理的問題
這篇文章主要介紹了Windows下用Nginx配置https服務(wù)器及反向代理的問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09Nginx實(shí)現(xiàn)404頁面的幾種方法(三種)
一個(gè)網(wǎng)站項(xiàng)目,肯定是避免不了404頁面的,通常使用Nginx作為Web服務(wù)器時(shí),有些相關(guān)配置方法,下面小編給大家?guī)砹薔ginx實(shí)現(xiàn)404頁面的幾種方法,感興趣的朋友一起看看吧2018-08-08Windows Server 2016 MySQL數(shù)據(jù)庫安裝配置詳細(xì)安裝教程
這篇文章主要介紹了Windows Server 2016 MySQL數(shù)據(jù)庫安裝配置詳細(xì)安裝教程,需要的朋友可以參考下2017-08-08Nginx Location指令URI匹配規(guī)則詳解小結(jié)
這篇文章主要介紹了Nginx Location指令URI匹配規(guī)則詳解小結(jié),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04Nginx服務(wù)器中的模塊編寫及相關(guān)內(nèi)核源碼初探
這篇文章主要介紹了Nginx服務(wù)器中的模塊編寫及相關(guān)源碼初探,文中以一個(gè)簡(jiǎn)單的Hello world模塊的編寫來深入分析Nginx內(nèi)核所用到的基礎(chǔ)函數(shù),需要的朋友可以參考下2015-12-12nginx?添加http_stub_status_module模塊
本文主要介紹了nginx?添加http_stub_status_module模塊,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05Nginx的location的常見規(guī)則優(yōu)先級(jí)問題
Nginx是反向代理和負(fù)載均衡的首選工具,nginx的location配置有許多細(xì)節(jié)內(nèi)容在網(wǎng)上不容易找到資料,或者解釋不清。本文對(duì)Nginx location規(guī)則優(yōu)先級(jí)介紹,需要的朋友參考下吧2021-08-08