[精讚] [會員登入]
1884

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

你可能感興趣的文章

自行撰寫syslog server建立資訊安全控管中心#2 -- 架構和作法 利用PERL將syslog收攏到資料庫的程式,架構和作法

[PERL] 16-字串取代和置換 Perl 字串比對及置換

[PERL] 04-基本比對 perl的正規表達示基本比對

[PERL] Regex 字元集(群組) 幾個Perl在regular express會用到的特殊符號notation:字元集

[PERL] 12- 副程式 Perl 的副程式就是所謂的函數

[PERL] 自寫 trim, ltrim, rtrim 函數 常用的 perl 函數中沒有trim, ltrim, rtrim這三個函數,那就自己來寫,非常容易

隨機好文

使用Google尋找你的手機 這近發現google竟然可以用來找android的手機,而且不需要經過什麼設定或安裝軟體。

[jQuery] 利用load()來達成ajax的寫法 jQuery中利用load()來達成ajax的寫法,也有人稱他是假的ajax,作法就是..

UTF-8 BOM (Byte Order Mark) 的問題 在 Michael Kaplan 那看到 Every character has a story #4: U+feff

PHP for sphinx 函式庫安裝 PECL/sphinx PHP>= 5.2.2 已經能原生支援 sphinx,可是預設的沒有裝,我們得自己裝才能用

[Win7] 燒錄 iso 檔 在Windows7 中內建燒錄程式,可以直接把檔案拉到光碟機裡,再執行燒錄。