HTTPS 站點的性能優化

来源:https://www.cnblogs.com/Javame/archive/2018/09/30/9722456.html
-Advertisement-
Play Games

HTTPS 站中的幾大難題 性能,包括: 其次,相容性及周邊,如: 如何解決 採用了統一接入層的架構,並配備管控平臺。這樣的設計解決了很多問題,比如證書分散且落地不安全、軟體版本難以維護、配置過多、難以標準和自動化、VIP 過多等; 以功能變數名稱收斂的方式減少建連; 採用 HSTS 技術去掉 80 到 4 ...


HTTPS 站中的幾大難題

性能,包括:

  1. HTTPS需要多次握手,因此網路耗時變長,用戶從HTTP跳轉到HTTPS需要一些時間;
  2. HTTPS要做RSA校驗,這會影響到設備性能;
  3. 所有CDN節點要支持HTTPS,而且需要有極其複雜的解決方案來面對DDoS的挑戰。

其次,相容性及周邊,如:

  1. 頁面里所有嵌入的資源都要改成HTTPS的,這些資源可能會來自不同的部門甚至不同的公司,包括圖片、視頻、表單等等,否則瀏覽器就會報警。

如何解決

  • 採用了統一接入層的架構,並配備管控平臺。這樣的設計解決了很多問題,比如證書分散且落地不安全、軟體版本難以維護、配置過多、難以標準和自動化、VIP 過多等;
  • 以功能變數名稱收斂的方式減少建連;
  • 採用 HSTS 技術去掉 80 到 443 的 302 跳轉;
  • 通過 Session 復用來提高建連速度和降低伺服器壓力;
  • 對證書鏈進行優化以減少證書的傳輸量;
  • 摒棄傳統的 RSA 演算法,轉而使用了最新的 ECDH 密鑰交換演算法,極大地提升了服務端的性能。

關註安全與相容性

  • 採用了雙證書模式,即SHA-1和SHA-256,最大限度地保證安全和相容性;
  • 使用的是相容性最寬泛的 OV 證書,全面支持單功能變數名稱、多功能變數名稱和泛功能變數名稱,滿足多種瀏覽器訪問,保證最好的用戶體驗,當然代價也是費用較為昂貴;
  • 引入泛功能變數名稱 SAN 證書。

其次是一篇關於 Nginx 中 SSL 性能優化的文章《Nginx SSL 性能優化》。

密鑰交換演算法

常見的密鑰交換演算法有 RSA,ECDHE,DH,DHE 等演算法。它們的特性如下:

  • RSA:演算法實現簡單,誕生於 1977 年,歷史悠久,經過了長時間的破解測試,安全性高。缺點就是需要比較大的素數(目前常用的是 2048 位)來保證安全強度,很消耗 CPU 運算資源。RSA 是目前唯一一個既能用於密鑰交換又能用於證書簽名的演算法。
  • DH:diffie-hellman 密鑰交換演算法,誕生時間比較早(1977 年),但是 1999 年才公開。缺點是比較消耗 CPU 性能。
  • ECDHE:使用橢圓曲線(ECC)的 DH 演算法,優點是能用較小的素數(256 位)實現 RSA 相同的安全等級。缺點是演算法實現複雜,用於密鑰交換的歷史不長,沒有經過長時間的安全攻擊測試。
  • ECDH:不支持 PFS,安全性低,同時無法實現 false start。
  • DHE:不支持 ECC。非常消耗 CPU 資源 。

建議優先支持 RSA 和 ECDH_RSA 密鑰交換演算法。原因是:

  • ECDHE 支持 ECC 加速,計算速度更快。支持 PFS,更加安全。支持 false start,用戶訪問速度更快。
  • 目前還有至少 20% 以上的客戶端不支持 ECDHE,我們推薦使用 RSA 而不是 DH 或者 DHE,因為 DH 系列演算法非常消耗 CPU(相當於要做兩次 RSA 計算)。

更改其配置如下(參照 Nginx Performance Tuning for SSL( http://dojo.techsamurais.com/?p=1384 ):

1 2 3 4 5 ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers ECDHE-RSA-AES256-SHA384:AES256-SHA256:RC4:HIGH:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!AESGCM; ssl_prefer_server_ciphers on; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m;

或者

1 ssl_ciphers ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES128-SHA256:ECDHE-RSA-AES128-SHA256:ECDHE-ECDSA-RC4-SHA:!ECDHE-RSA-RC4-SHA:ECDH-ECDSA-RC4-SHA:ECDH-RSA-RC4-SHA:ECDHE-RSA-AES256-SHA:!RC4-SHA:HIGH:!aNULL:!eNULL:!LOW:!3DES:!MD5:!EXP:!CBC:!EDH:!kEDH:!PSK:!SRP:!kECDH;

(禁用了RC4,sha1,MD5等演算法)

輔助加速

啟用SPDY

SPDY 是 Google 推出的優化 HTTP 傳輸效率的協議( https://www.chromium.org/spdy ), 它基本上沿用了 HTTP 協議的語義, 但是通過使用幀控制實現了多個特性,顯著提升了 HTTP 協議的傳輸效率。

SPDY 最大的特性就是多路復用,能將多個 HTTP 請求在同一個連接上一起發出去,不像目前的 HTTP 協議一樣,只能串列地逐個發送請求。

可以在編譯Nginx帶上參數 –with-http_spdy_module 支持 SPDY 協議,然後可在配置中啟用:

1 listen 443 ssl spdy;

檢測是否使用SPDY的網址( https://spdycheck.org/ )

HSTS

HSTS(HTTP Strict Transport Security)。服務端返回一個 HSTS 的 http header,瀏覽器獲取到 HSTS 頭部之後,在一段時間內,不管用戶輸入 www.baidu.com 還是 http://www.baidu.com ,都會預設將請求內部跳轉成 https://www.baidu.com;

將下述行添加到你的 HTTPS 配置的 server 塊中:

1 add_header Strict-Transport-Security "max-age=31536000";

Session cache

Session cache 的原理是使用 client hello 中的 session id 查詢服務端的 session cache, 如果服務端有對應的緩存,則直接使用已有的 session 信息提前完成握手,稱為簡化握手。

Session cache 有兩個缺點:

  1. 需要消耗服務端記憶體來存儲 session 內容。
  2. 目前的開源軟體包括 nginx,apache 只支持單機多進程間共用緩存,不支持多機間分散式緩存,對於百度或者其他大型互聯網公司而言,單機 session cache 幾乎沒有作用。

Session cache 也有一個非常大的優點:session id 是 TLS 協議的標準欄位,市面上的瀏覽器全部都支持 session cache。

1 2 ssl_session_cache shared:SSL:20m; ssl_session_timeout 20m;

參照 Nginx 的官方文檔 1MB 記憶體大約可以存儲 4000 個 session,按例配置 20M 大約可以存儲 80000。根據需求合理設置。

Ocsp stapling

Ocsp 全稱線上證書狀態檢查協議 (rfc6960),用來向 CA 站點查詢證書狀態,比如是否撤銷。通常情況下,瀏覽器使用 OCSP 協議發起查詢請求,CA 返回證書狀態內容,然後瀏覽器接受證書是否可信的狀態。 將證書保存下來,瀏覽器請求時候直接通過自己的伺服器發送回去,防止驗證伺服器出問題,還能加快訪問速度。

查看OSCP驗證伺服器地址:

1 openssl x509 -in 1_test.qupeiyin.net_bundle.crt  -text

在輸出的文字中找到 OCSP - URI: ,後面的 URL 就是 OSCP 的驗證伺服器地址。

請求 OSCP 證書

1 2 3 4 openssl ocsp -noverify \ -issuer /certificate-path/trustchain.crt \ -cert /certificate-path/trustchain.crt \ -url http://ocsp1.wosign.com/ca6/server1

不出意外會收到如下的結果

1 2 3 trustchain.crt: good            This Update: Oct 18 17:59:10 2014 GMT            Next Update: Oct 18 23:59:10 2014 GMT

如果出現 403 錯誤,那就需要在 Header 請求頭加上功能變數名稱參數如 -header “HOST” “ocsp2.globalsign.com” ,沒問題後就可以直接保存下來證書文件,完整的命令如下:

1 2 3 4 openssl ocsp -noverify  -issuer 1_root_bundle.crt -cert 1_root_bundle.crt -url http://ocsp1.wosign.com/ca6/server1  -header "HOST" "ocsp1.wosign.com" -text -respout ./stapling_file.ocsp

將保存下來的 stapling_file.ocsp 證書添加到 nginx 的配置中,如下,Nginx 中配置變成了這樣子:

1 2 3 4 ssl_stapling on; ssl_stapling_verify on; ssl_stapling_file /stapling_file.ocsp; ssl_trusted_certificate /certificate-path/trustchain.crt;

這樣子重啟 Nginx 後就會生效,可以使用下麵的命令測試生效結果:

1 echo QUIT | openssl s_client -connect blog.alphatr.com:443 -status 2> /dev/null | grep -A 17 'OCSP response:' | grep -B 17 'Next Update'

看到 OCSP Response Status: successful 這樣的字樣就是成功了。

ocsp證書有效期很短,大概不到一個月,所以過段時間要更新 ocsp 證書,不然還是會驗證失敗。需要用腳本定時更新OCSP證書。

總結:(全部優化參數)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ssl on; ssl_certificate /data/www/ssl/ssl.crt; ssl_certificate_key /data/www/ssl/ssl.key; ssl_trusted_certificate /data/www/ssl/trustchain.crt; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers ECDHE-RSA-AES256-SHA384:AES256-SHA256:RC4:HIGH:!MD5:!aNULL:!eNULL:!NULL:!DH:!EDH:!AESGCM; ssl_prefer_server_ciphers on; ssl_stapling on; ssl_stapling_verify on; ssl_session_cache shared:SSL:10m; ssl_session_timeout 10m; add_header Strict-Transport-Security "max-age=31536000"; resolver 223.5.5.5 223.6.6.6 valid=300s; resolver_timeout 10s; error_page 497 https://$host$request_uri;

參數詳解:

ssl on  開啟SSL

ssl_certificate  對應單張證書

ssl_certificate_key  對應私鑰

ssl_trusted_certificate  對應信任鏈(即Startcom SSL或者Positive SSL中需要附加到單張證書後面的那兩張證書,可以獨立出來)

ssl_protocols  支持的SSL協議標準(nginx預設參數為:ssl_protocols SSLv3 TLSv1 TLSv1.1 TLSv1.2;)

ssl_ciphers  (nginx預設參數為:ssl_ciphers HIGH:!aNULL:!MD5;)

ssl_prefer_server_ciphers On;  指定伺服器密碼演算法在優先於客戶端密碼演算法時,使用SSLv3和TLS協議。

error_page 497 https://$host$request_uri;  通過497錯誤將http轉跳到https


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 騰訊防水牆(滑動驗證碼)的簡單使用 https://007.qq.com ...
  • 騰訊地圖點擊地圖創建錨點(且只創建一個)同事創建錨點提示。 qq.maps.event.addListener(marker, 'click', function() { 44 info.open(); 45 info.setContent('單擊標記'); 47... ...
  • 今天分享一下快速使用jQuery+zepto.js的技巧,需要的記得收藏 1.jQuery的引入:本地下載jQuery(後面簡稱jq)的源文件,開發版本使用非min版,線上使用min版,zepto.js類似,同樣的一些基於jq的插件也是如此用法,如果使用requreJs也就是模塊化載入註意插件的依賴 ...
  • 叨叨一會CommonJS Common這個英文單詞的意思,相信大家都認識,我記得有一個片語common knowledge是常識的意思,那麼CommonJS是不是也是類似於常識性的,大家都理解的意思呢?很明顯不是,這個常識一點都不常識。我最初認為commonJS是一個開源的JS庫,就是那種非常方便用 ...
  • webpack的打包依賴於它的一個重要配置文件webpack.config.js,在這個配置文件中就可以指定所有在源代碼編譯過程中的工作了,就一個配置就可以與冗長的Gruntfile或者Gulpfile說再見了。 一個完整的工程項目中的webpack的配置遠遠沒有這麼簡單,隨著工程的構建要求的增加, ...
  • 最近一個月,恍若隔世,天天加班,昨晚終於發版了,今天才喘一口氣。有時候,即便你工作效率再怎麼高,擼碼再怎麼快也無可避免的會加班。不信的話,可以先給你定一個交付時間,然後不斷的給你加需求,就讓你一個人做,偶爾再給你來幾下變更,看你怎麼死?本來做項目,需求、資源、時間就是一個鐵三角,一旦你強行要打破這個 ...
  • 我們在上一篇說到如何把 Vue 實例中的數據顯示到視圖中,就會需要用到我們的模版,我們只是簡單的使用了一些,模版其實還有很多其他的特性。今天我們就來看看模版的其他特性。 模版語法 Vue 中的模版是基於 HTML 的模版語法,所有的 Vue 模版都是合法的 HTML ,所以能被遵循規範的瀏覽器和 H ...
  • 實習生張大胖這是個代碼寫得很爛的電商系統,只要運行一段時間,伺服器就會出現Out Of Memory。別人都忙得四腳朝天,於是實習生張大胖被抓了壯丁去研究為什麼會出現OOM。剛入行的張大胖技術水平一般,“裝模作樣”地看代碼,研究日誌,請教老員工,一個星期過去了,還是一無所獲。周一例行的項目會議上, ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...