[精讚] [會員登入]
2167

Apache Worker MPM =worker 調整參數

Apache目前一共有三種穩定的MPM(Multi-Processing Module,多進程處理模式 簡稱: MPM)

分享此文連結 //n.sfs.tw/15558

分享連結 Apache Worker MPM =worker 調整參數@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
最後編修
2022-01-06 14:56:06 By 張○○
 

自動目錄

Apache目前一共有三種穩定的MPM(Multi-Processing Module,多進程處理模式 簡稱: MPM) 它們分別是prefork,worker和event,它們同時也代表這Apache的演變和發展。在編譯Apache時必須選擇其中一個MPM,MPM會影響到Apache的速度和可伸縮性。[1]

apache2.0默認prefork, 2.2默認為worker, 2.4版本是event。

此篇著重於worker模式的設定,其運作優缺點在[1]中有詳細說明:

查看 mpm

$ httpd -V
Server version: Apache/2.4.37 (centos)
Server built:   Nov 12 2021 04:57:27
Server's Module Magic Number: 20120211:83
Server loaded:  APR 1.6.3, APR-UTIL 1.6.1
Compiled using: APR 1.6.3, APR-UTIL 1.6.1
Architecture:   64-bit
Server MPM:     worker
  threaded:     yes (fixed thread count)
    forked:     yes (variable process count)
Server compiled with....
 -D APR_HAS_SENDFILE
 -D APR_HAS_MMAP
... 中略 ...
 -D AP_TYPES_CONFIG_FILE="conf/mime.types"
 -D SERVER_CONFIG_FILE="conf/httpd.conf"

 

Worker 調整參數

參數的調整主要參考[2]的詳細說明,基本上簡單整理下:

  1. 最大子行程數ServerLimit=100 x 每子行程執行緒數ThreadsPerChild=250 = 最大執行緒數=25000
  2. 開始的子行程數StartServers =50
  3. 最小閒置執行緒數MinSpareThreads=50<=閒置執行緒數<=最大閒置執行緒數MaxSpareThreads=250
  4. 子行程生命週其最大連線數=0,即不限制

 

# vim /etc/httpd/conf.modules.d/00-mpm.conf

#LoadModule mpm_event_module modules/mod_mpm_event.so <== 原本的註解

LoadModule mpm_worker_module modules/mod_mpm_worker.so
KeepAlive Off

<IfModule worker.c>
ServerLimit               100
StartServers               50
ThreadsPerChild           250
MinSpareThreads            50
MaxSpareThreads           250
MaxConnectionsPerChild      0
</IfModule>

 

測試效能

使用ab去壓測,測試10000個連線

$ ab -s 30 -n 10000 http://192.168.0.1/

調整前後測試數據

兩張對比圖分別是左調整前和右調整後的跑分,單位是ms數字越小越好。

右圖調整參數為上面的參數,大幅改善第100%的處理能力,由約1.6s減少為0.1s。

測試的網頁為單純的靜態網頁,沒有資料庫或其它程式的影響,因此比較能排除其它效能瓶頸導致的問題。

 

參考資料

[1] 阿輝的零碎筆記 https://dotblogs.com.tw/grayyin/2020/03/15/115350

[2] https://www.brilliantcode.net/877/apache-2-2-2-4-performance-tuning-mpm-engine/?cli_action=1641434802.1

[3] https://www.brilliantcode.net/2135/apache-advance-settings-keepalive/

END

你可能感興趣的文章

[PERL] 05-運算子 #1 PERL的運算子介紹,總共有21種

[PERL]] find 和 perl 的結合--大量檔案中文字的取代 利用PERL作大量的文件取代

PERL 正規表達式會用到的符號 PERL在比對時常常會用到符號整理

[PERL] 19-模組的安裝和維護 模組的安裝和維護

[PERL] 06-運算子 #2 PERL的運算子介紹,總共有21種

[PERL] 23-多執行緒 而多執行緒的程式,可在一次執行程式時間,同時進行多線程的計算,在效率上可獲得即大的提升。

隨機好文

如何在linux下執行java 原生的java應用程式可以使用簡單的方法在console下面寫出來,適合作簡單的應用

[bc] linux 的計算機 bc 設定小數位數、計算π、次方根 linux 的計算機 bc 設定小數位數、計算π、次方根

[JAVA] JWS, JWT, JWE, JOSE是什麼? [JAVA] JWS, JWT, JWE, JOSE是什麼?非常的複雜,儘量來搞清楚..

Smarty安裝 smarty 是著名的樣版引擎,非常的好用,用多了突然發現拿掉smarty反而不會寫php了,以下是安裝過程..

詭異的創業思維 創業的思維中,有多少銀彈,有多少技術,有多少人脈,有多少時間等等,每個都要考慮進去,以熱忱建立的關係脆弱的像蘇打餅乾一樣..