背景
我們七層負載層,使用了5台24U+64G記憶體的實體機支行nginx做https加解密與proxy_pass。每天上下班時段,5台機CPU基本上在50%左右,算是計算型。
最佳化手段:keepalive、換TLS1.2加密演算法最佳化(參考:1,2)等,收效不大。
特別簡潔keepalive選項,不論服務端如何支持,關鍵是客戶端不跟你keep,你玩個屁。
測試過程
- 硬體: 24U+64G物理機2台,1台跟測試,1台跑ngx; 同個區域網路內,1GB網卡。
-
nginx -V:
version: openresty/1.9.7.3
built by gcc 4.8.5 20150623 (Red Hat 4.8.5-4) (GCC)
built with OpenSSL 1.0.1e-fips 11 Feb 2013
TLS SNI support enabled
–with-http_v2_module Apache的ab壓測工具: yum安裝
- boom 是模擬ab的golang實現的壓測工具: https://github.com/rakyll/boo /boo
- 測試工具: https://github.com/tatsuhiro-t/nghttp2
- CentOS-7 64位元
- 測試檔案大小:5k,10k的圖片,作靜態檔案的https測試。
- 測試過程簡單來看參數:-c=100~3000,-n=1k~10kw 的各種組合, 使用h2load時-m=1~1000都有試過,-m範圍大小,對http2結果影響不太大。
圖:
放流量圖你就明白了:
下圖為使用ab與boom時:
此時ab與boom都有使用-k,反正怎麼玩,測量與時間都大概在這個水平。
例如以下指令,基本上要跑半小時:
boom -c 1000 -n 1000000 -allow-insecure https://172.16.9.234/5k.jpg
ab -c 1000 -n 1000000 -khttps://172.16.9.234/5k.jpg
參數不變換成http2時:
h2load -c 1000 -n 100000751/100751/100 .jpg
h2load運行結果如下:
再有下圖為h2load測試http2時:
千兆網路卡,流出流量全滿上。
結論
以下結論經過多次重複測試,只代表本人意見,轉載請註明from:toontong.
- 同等並發數下,http2.0只用了43秒傳輸完4.3G數據;而http1 .1用40多分鐘。
- 單論傳輸效能提升10倍不止,對我們關鍵的https CPU佔用效果非常明顯。
- 對web服務整體效能提升當然沒10倍,原因還有連線建立在需時等,更多原因要深研http2原理了。
- go1.6後才有http2-client庫的支持,低版本go感覺可以使用https://github.com/tatsuhiro-t/go-nghttp2
- 如果真普及http2.0,對整個互聯流量,網路公司的機器節約,都是大福音。
').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });
以上就介紹了nginx的http20效能太逆天了,HTTPS網站效能優化,包含了方面的內容,希望對PHP教學有興趣的朋友有幫助。

負載均衡會影響會話管理,但可以通過會話複製、會話粘性和集中式會話存儲解決。 1.會話複製在服務器間複製會話數據。 2.會話粘性將用戶請求定向到同一服務器。 3.集中式會話存儲使用獨立服務器如Redis存儲會話數據,確保數據共享。

Sessionlockingisatechniqueusedtoensureauser'ssessionremainsexclusivetooneuseratatime.Itiscrucialforpreventingdatacorruptionandsecuritybreachesinmulti-userapplications.Sessionlockingisimplementedusingserver-sidelockingmechanisms,suchasReentrantLockinJ

PHP會話的替代方案包括Cookies、Token-basedAuthentication、Database-basedSessions和Redis/Memcached。 1.Cookies通過在客戶端存儲數據來管理會話,簡單但安全性低。 2.Token-basedAuthentication使用令牌驗證用戶,安全性高但需額外邏輯。 3.Database-basedSessions將數據存儲在數據庫中,擴展性好但可能影響性能。 4.Redis/Memcached使用分佈式緩存提高性能和擴展性,但需額外配

Sessionhijacking是指攻擊者通過獲取用戶的sessionID來冒充用戶。防範方法包括:1)使用HTTPS加密通信;2)驗證sessionID的來源;3)使用安全的sessionID生成算法;4)定期更新sessionID。

本文比較了PHP和ASP.NET,重點是它們對大規模Web應用程序,性能差異和安全功能的適用性。兩者對於大型項目都是可行的,但是PHP是開源和無關的,而ASP.NET,


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Dreamweaver Mac版
視覺化網頁開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

Atom編輯器mac版下載
最受歡迎的的開源編輯器

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具