伺服器執行緒數優化

1. 伺服器執行緒概念

一般伺服器都需要承受較高的存取量,能夠同時回應不同使用者的請求,在伺服器中使用執行緒來處理接收的每個請求,若能夠合理管理執行緒數,伺服器就能夠更好的在惡劣環境下保持較高的穩定性和健壯性。

各 Web 伺服器管理執行緒主要用到如下幾個參數:

  • 最小執行緒數伺服器最少保證的執行緒數;

  • 最大執行緒數伺服器併發處理的最大任務個數,超過該數時,請求會進入等待,等待閒置執行緒;

  • 最大等待時間伺服器執行緒數超過最大執行緒數,進入等待的請求,超過最大等待時間時,伺服器會絕此次請求,傳回 connection refused。

2. 如何設定伺服器執行緒數

一般的伺服器操作都包括兩方面:計算(主要消耗 CPU)、等待(IO、資料庫等),最重要的參數就是“最大執行緒數”:

第一種極端情況,如果我們的操作是純粹的計算,那麼系統回應時間的主要限制就是 CPU 的運算能力,此時最大執行緒數應該儘量設的小,降低同一時間內爭搶 CPU 的執行緒個數,可以提高計算效率,提高系統的整體處理能力。

第二種極端情況,如果我們的操作是純粹IO或者資料庫,那麼回應時間的主要限制就變為等待外部資源,此時最大執行緒數應該儘量設的大,這樣才能提高同時處理請求的個數,進而提高系統整體的處理能力。此情況下因為Tomcat同時處理的請求量會比較大,所以需要關注一下 Tomcat 的虛擬機記憶體設定和 Linux 的 open file 限制。

而現實應用中,我們的操作都會包含以上兩種類型(計算、等待),所以最大執行緒數的配置並沒有一個最優值,一定要根據具體情況來配置。

最好的做法是:在不斷測試的基礎上,不斷調整、優化,才能得到最合理的配置。


索引:

Tomcat 伺服器併發數查看與修改

附件列表


主題: 效能優化
已經是第一篇
已經是最後一篇
  • 有幫助
  • 沒幫助
  • 只是瀏覽
中文(繁體)

滑鼠選中內容,快速回饋問題

滑鼠選中存在疑惑的內容,即可快速回饋問題,我們將會跟進處理。

不再提示

7s后關閉

獲取幫助
線上支援
獲取專業技術支援,快速幫助您解決問題
工作日9:00-12:00,13:30-17:30在线
頁面反饋
針對當前網頁的建議、問題反饋
售前咨詢
業務咨詢
電話:0933-790886或 0989-092892
郵箱:taiwan@fanruan.com
頁面反饋
*問題分類
不能為空
問題描述
0/1000
不能為空

反馈已提交

网络繁忙

反饋已提交

網絡繁忙