中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

apache worker性能調優

發布時間:2020-06-16 02:01:18 來源:網絡 閱讀:2249 作者:_追隨我心 欄目:軟件技術

worker的工作原理及配置 
  相對于prefork,worker是2.0 版中全新的支持多線程和多進程混合模型的MPM。由于使用線程來處理,所以可以處理相對海量的請求,而系統資源的開銷要小于基于進程的服務器。但是,worker也使用了多進程,每個進程又生成多個線程,以獲得基于進程服務器的穩定性。這種MPM的工作方式將是Apache 2.0的發展趨勢。 
  在configure -with-mpm=worker后,進行make編譯、make install安裝。在缺省生成的
httpd.conf中有以下配置段:
StartServers 2 
MaxClients 150 
MinSpareThreads 25 
MaxSpareThreads 75 
ThreadsPerChild 25 
MaxRequestsPerChild 0 
  worker的工作原理是,由主控制進程生成“StartServers”個子進程,每個子進程中包含固定的ThreadsPerChild線程數,各個線程獨立地處理請求。同樣,為了不在請求到來時再生成線程,MinSpareThreads和MaxSpareThreads設置了最少和最多的空閑線程數;而MaxClients設置了所有子進程中的線程總數。如果現有子進程中的線程總數不能滿足負載,控制進程將派生新的子進程。 
  MinSpareThreads和MaxSpareThreads的最大缺省值分別是75和250。這兩個參數對Apache的性能影響并不大,可以按照實際情況相應調節。 
  ThreadsPerChild是worker MPM中與性能相關最密切的指令。ThreadsPerChild的最大缺省值是64,如果負載較大,64也是不夠的。這時要顯式使用ThreadLimit指令,它的最大缺省值是20000。上述兩個值位于源碼樹server/mpm/worker/worker.c中的以下兩行: 
#define DEFAULT_THREAD_LIMIT 64 
#define MAX_THREAD_LIMIT 20000 
  這兩行對應著ThreadsPerChild和ThreadLimit的限制數。最好在configure之前就把64改成所希望的值。注意,不要把這兩個值設得太高,超過系統的處理能力,從而因Apache不起動使系統很不穩定。 
  Worker模式下所能同時處理的請求總數是由子進程總數乘以ThreadsPerChild值決定的,應該大于等于MaxClients。如果負載很大,現有的子進程數不能滿足時,控制進程會派生新的子進程。默認最大的子進程總數是16,加大時也需要顯式聲明ServerLimit(最大值是20000)。這兩個值位于源碼樹server/mpm/worker/worker.c中的以下兩行: 
#define DEFAULT_SERVER_LIMIT 16 
#define MAX_SERVER_LIMIT 20000 
  需要注意的是,如果顯式聲明了ServerLimit,那么它乘以ThreadsPerChild的值必須大于等于MaxClients,而且MaxClients必須是ThreadsPerChild的整數倍,否則Apache將會自動調節到一個相應值(可能是個非期望值)。下面是常用worker配置段: 
StartServers 3 
MaxClients 2000 
ServerLimit 25 
MinSpareThreads 50 
MaxSpareThreads 200 
ThreadLimit 200 
ThreadsPerChild 100 
MaxRequestsPerChild 0 
  通過上面的敘述,可以了解到Apache 2.0中prefork和worker這兩個重要MPM的工作原理,并可根據實際情況來配置Apache相關的核心參數,以獲得最大的性能和穩定性。

附:以下個人理解,恐怕有誤。

StartServers 3   //apache已啟動馬上創建3個httpd進程(ps aux可以看到)
MaxClients 2000   //同一時間最大接受2000個請求(其實就是2000個線程)
ServerLimit 25 //apache最大能啟動25個進程。
MinSpareThreads 50 //apache至少要有50個空閑線程,用來等待接下來的請求,不滿則由進程創建線程
MaxSpareThreads 200 //apache最多能有200個線程,超出了200個線程,則殺死多余的線程
ThreadLimit 200 //限制一個進程最多只能創建200個線程
ThreadsPerChild 100 //設定一個進程固定創建100個線程
MaxRequestsPerChild 10000   //設定當一個進程一共接受過10000此請求之后被殺死。以釋放內存。

   從上面的配置我們可以看出,當apache啟動時,啟動3個httpd進程,每個進程又生成100個線程,但是超過了最大限定的數字,于是殺死100個線程,也就是一個進程。當某個時候有300個請求,目前只有200個線程,于是父進程再創建2個子進程。等請求處理完畢后,在把閑置釋放到只剩下200個以內。


向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

喀喇| 肥东县| 武宣县| 漳州市| 专栏| 南雄市| 隆林| 田阳县| 嘉峪关市| 江永县| 博白县| 长海县| 浦北县| 库尔勒市| 磐石市| 平邑县| 邓州市| 东兰县| 新安县| 宿迁市| 上饶县| 广德县| 青阳县| 岳普湖县| 专栏| 高要市| 乐清市| 灵台县| 许昌市| 宝应县| 南木林县| 南丹县| 乐都县| 天台县| 三台县| 乌拉特前旗| 仙游县| 子长县| 大理市| 康马县| 昌都县|