apache中mpm分析

1、什麼是MPM?
Multi-Processing Module (MPM) implements a hybrid multi-process multi-threaded server。(多進程、多線程)

2、有多少種MPM?
大致有:prefork MPM、worker MPM、BeOS MPM、NetWare MPM、OS/2 MPM、WinNT MPM。   

3、怎麼知道apache當前用的是哪個MPM?
linux及windows下都可以使用命令:“httpd -l ” 進行查詢。

4、各個MPM是怎麼工作及如何優化?
(1)prefork MPM
         <IfModule mpm_prefork_module>
             StartServers                 10
             MinSpareServers         10
             MaxSpareServers         15
             ServerLimit                   2000
             MaxClients                    1000
             MaxRequestsPerChild 10000
         </IfModule>
         啓動時建立StartServers個子進程,
         然後按每秒創建指數級個進程直到達到MinSpareServers個進程(最多增到每秒32個),
         如果空閒進程數大於MaxSpareServers,則檢查kill掉一些空閒進程。
         MaxRequestPerChild指定每個進程處理了多少個請求後就自我毀滅。
         MaxClients指定apache最多可以同時處理的請求數,也就是進程數?
         MaxClients默認不能大於256,可以通過設定ServerLimit來增大這個限制數,最大20000?

(2)worker:
         <IfModule mpm_worker_module>
             StartServers                   3
             MaxClients                      2000
             ServerLimit                     25
             ThreadLimit                    200
             ThreadsPerChild            100
             MinSpareThreads          50
             MaxSpareThreads         200
             MaxRequestsPerChild    0
         </IfModule>
         啓動時建立StartServers個子進程,
         每個進程包含ThreadsPerChild個線程,缺省最大64
         MinSpareThreads定義最小的空閒線程數,最大75
         MaxSpareThreads定義最大的空閒線程數,超過則執行清理?最大250
         MaxClients定義所有子進程中的線程總數
         ThreadLimit,最大20000,默認64
         ServerLimit,最大值20000,默認16
          需要注意的是,如果顯式聲明瞭ServerLimit,那麼它乘以ThreadsPerChild的值必須大於等於MaxClients,而且 MaxClients必須是ThreadsPerChild的整數倍,否則Apache將會自動調節到一個相應值(可能是個非期望值)。

(3)WinNT MPM:
         <IfModule mpm_winnt_module>
             ThreadsPerChild          500
             MaxRequestsPerChild 10000
         </IfModule>
         mpm_winnt.c是專門針對Windows   NT優化的MPM(多路處理模塊),它使用一個單獨的父進程產生一個單獨的子進程,在這個子進程中輪流產生多個線程來處理請求。也就是說 mpm_winnt只能啓動父子兩個進程, 不能像Linux下那樣同時啓動多個進程。
ThreadLimit,默認1920,最大15000,限制單個進程的線程總數。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章