首頁  >  文章  >  運維  >  apache修改最大並發連線數

apache修改最大並發連線數

王林
王林轉載
2020-10-26 16:38:153176瀏覽

apache修改最大並發連線數

Apache為不同的作業系統提供了多個不同的MPM模組,例如:mpm_beos、mpm_event、mpm_netware、mpmt_os2、mpm_prefork、mpm_winnt、mpm_worker。如果條件允許,我們可以根據實際需求將指定的MPM模組編譯進我們自己的Apache中(Apache的源碼是開放的,允許使用者自行編譯)。不過,如果在編譯時我們沒有選擇,Apache將依照以下表格根據不同的作業系統自行選擇對應的MPM模組,這也是Apache針對不同平台建議使用的MPM模組。

(建議教學:apache

不同作業系統上預設的MPM模組

作業系統MPM模組描述

Windowsmpm_winnt不用介紹了吧:)

Unix/Linuxmpm_prefork不用介紹了吧:)

BeOSmpm_beos由Be公司開發的一種多媒體作業系統,官方版已停止更新。

Netwarempm_netware由NOVELL公司推出的一種網路作業系統

OS/2mpmt_os2一種最初由微軟和IBM共同開發的作業系統,現由IBM單獨開發(微軟放棄OS/2 ,轉而開發Windows)

mpm_event模組可以看作是mpm_worker模組的一個變種,不過其具有實驗性質,一般不建議使用。

當然,Apache在其官方網站上也提供了根據不同作業系統已經編譯好對應MPM模組的成品Apache。你可以點擊此處進入Apache官方網站下載。

此外,如果我們想要知道某個Apache內部使用的是何種MPM模組,我們可以以命令列的方式進入Apache安裝目錄\bin,然後鍵入命令httpd -l,即可查看到目前Apache內部使用的何種MPM模組。

使用httpd -l指令查看編譯模組

由於在平常的開發工作中,BeOS、NetWare、OS/2等作業系統並不常見,這裡我們主要針對Windows和Unix/ Linux作業系統上的MPM模組進行解說。在Windows和Unix/Linux作業系統上,MPM模組主要有mpm_winnt、mpm_prefork、mpm_worker三種。

mpm_prefork模組

mpm_prefork模組主要應用於Unix/Linux平台的Apache伺服器,其主要工作方式是:當Apache伺服器啟動後,mpm_prefork模組會預先建立多個子程序(預設為5個),當接收到客戶端的請求後,mpm_prefork模組再將請求轉交給子程序處理,並且每個子程序同時只能用於處理單一請求。如果目前的請求數將超過預先建立的子程序數時,mpm_prefork模組就會建立新的子程序來處理額外的請求。 Apache總是試圖保持一些備用的或是空閒的子程序用來迎接即將到來的請求。這樣客戶端的請求就不需要在接收後等候子程序的產生。

由於在mpm_prefork模組中,每個請求對應一個子進程,因此其佔用的系統資源相對其他兩種模組而言較多。不過mpm_prefork模組的優點在於它的每個子程序都會獨立處理對應的單一請求,這樣,如果其中一個請求出現問題就不會影響到其他請求。同時,mpm_prefork模組可以應用於不具備線程安全的第三方模組(例如PHP的非線程安全版本),並且在不支援線程調試的平台上易於調試。此外,mpm_prefork模組還具有比mpm_worker模組更高的穩定性。

mpm_worker模組

mpm_worker模組也主要應用於Unix/Linux平台的Apache伺服器,它可以看作是mpm_prefork模組的改良版。 mpm_worker模組的運作方式與mpm_prefork模組類似。不過,由於處理相同請求的情況下,基於進程(例如mpm_prefork)比基於執行緒的處理方式所佔用的系統資源要多。因此,與mpm_prefork模組不同的是,mpm_worker模組會讓每個子程序創建固定數量的服務線程和一個監聽線程,並讓每個服務線程來處理客戶端的請求,監聽線程用於監聽接入請求並將其傳遞給服務線程處理和應答。 Apache總是試圖維持一個備用或是空閒的服務執行緒池。這樣,客戶端無須等待新執行緒或新行程的建立即可處理。

與mpm_prefork模組相比,mpm_worker模組可以進一步減少系統資源的開銷。再加上它也使用了多進程,每個進程又有多個線程,因此它與完全基於線程的處理方式相比,增加了一定的穩定性。

mpm_winnt模組

mpm_winnt模組是專門針對Windows作業系統而最佳化設計的MPM模組。它只創建一個單獨的子進程,並在這個子進程中輪流產生多個執行緒來處理請求。

修改MPM模組配置

在對Apache的MPM模組具備一定了解後,我們就可以針對不同的MPM模組來修改Apache的最大並發連接數配置了。

1.啟用MPM模組設定檔

在Apace安裝目錄/conf/extra目錄中有一個名為httpd-mpm.conf的設定檔。此檔案主要用於進行MPM模組的相關配置。不過,在預設情況下,Apache的MPM模組設定檔並沒有啟用。因此,我們需要在httpd.conf檔中啟用該設定文件,如下所示:

# Server-pool management (MPM specific)Include conf/extra/httpd-mpm.conf(去掉該行前面的註解符號"#")

2.修改MPM模組設定檔中的相關設定

#在啟動MPM模組設定檔後,我們可以使用文字編輯器開啟該設定文件,我們可以看到,在該設定檔中有許多設定節點,如下圖所示:

只有Apache使用對應MPM模組時,對應設定才會生效

此時,我們就需要根據目前Apache伺服器所使用的MPM模組,來修改對應節點下的參數配置。首先,我們來看看mpm_winnt模組下的預設配置:

#由於mpm_winnt模組只會建立1個子進程,因此這裡對單一子進程的參數設定就相當於整個Apache的參數設定。 ThreadsPerChild      150#建議設定:小型網站=1000 中型網站=1000~2000 大型網站=2000~3500MaxRequestsPerChild    0#建議設定:小=10000 中或大對應配置

ThreadsPerChild

每個子程序的最大並發執行緒數。

MaxRequestsPerChild

每個子程序允許處理的請求總數。如果累積處理的請求數超過該值,該子進程將會結束(然後根據需要確定是否創建新的子進程),該值設為0表示不限制請求總數(子進程永不結束)。

此參數建議設為非零的值,可以帶來以下兩個好處:

可以防止程式中可能存在的記憶體洩漏無限進行下去,從而耗盡記憶體。

給進程一個有限壽命,從而有助於當伺服器負載減輕的時候減少活動進程的數量。

注意:在以上涉及統計請求數量的參數中,對於KeepAlive的連接,只有第一個請求會被計數。

接著,我們再來看看mpm_perfork模組和mpm_worker模組下的預設設定:

#mpm_perfork模組StartServers          5#建議設定:小=預設中=20~50 大=500~100MinSpare=20~50 大=50~Servers 5#建議設定:與StartServers保持一致MaxSpareServers      10#建議設定:小=20 中=30~80 大=80~120 MaxClients          150#建議設定:小=500 中小設定:小=10000 中或大=10000~500000(此外,還需額外設定ServerLimit參數,此參數最好與MaxClients的值保持一致。)

# StartServers:  数量的服务器进程开始
# MinSpareServers:  最小数量的服务器进程,保存备用
# MaxSpareServers:  最大数量的服务器进程,保存备用
# MaxRequestWorkers:  最大数量的服务器进程允许开始
# MaxConnectionsPerChild:  最大连接数的一个服务器进程服务

prefork 控製程序在最初建立“StartServers”個子進程後,為了滿足MinSpareServers設定的需要創建一個進程,等待一秒鐘,繼續創建兩個 個,再等待一秒鐘, 繼續創建四個…如此按指數級增加創建的進程數,最多達到每秒32個,直到滿足MinSpareServers設定的值為止。這種模式 可以不必在請求到 來時再產生新的進程,從而減少了系統開銷以增加效能。 MaxSpareServers設定了最大的空閒行程數,如果空閒行程數大於這個 值,Apache 會自動kill掉一些多餘行程。這個值不要設得太大,但如果設的值比MinSpareServers小,Apache會自動把其調整 為 MinSpareServers 1。若站點負載較大,可考慮同時增加MinSpareServers和MaxSpareServers。

MaxRequestsPerChild設定的是每個 子程序可處理的請求數。每個子程序在處理了「MaxRequestsPerChild」個請求後將自 動銷毀。 0意味著無限,即子程序永不銷毀。雖然預設為0可以使每個子進程處理更多的請求,但如果設為非零值也有兩點重要的好處:

1、可防止意外的記憶體洩 漏。 2.伺服器負載下降的時侯會自動減少子進程數。

因此,可根據伺服器的負載來調整這個值。

MaxRequestWorkers指令集同時將服務請求的數量上的限制。任何連線嘗試在MaxRequestWorkerslimit將通常被排隊,最多若干基於上ListenBacklog指令。

在apache2.3.13以前的版本MaxRequestWorkers稱為MaxClients 。

(MaxClients是這些指令中最為重要的一個,設定的是 Apache可以同時處理的請求,是對Apache效能影響最大的參數。其預設值150是遠遠不夠的,如果請求總數已達到這個值(可透過ps -ef|grep http|wc -l來確認),那麼後面的請求就要排隊,直到某個已處理請求完畢。這就是系統資源還剩下很多而HTTP訪問卻很慢的主要原因。雖然理論上這個值越大,可以 處理的請求就越多,但Apache預設的限制不能大於256。)

#mpm_worker模組StartServers          2#建議設定:小=預設中=3~5 大=5~10MaxClients          150#建議設定:小=500 中=5001500小=預設=50~100 大=100~200MaxSpareThreads      75#推薦:小=預設中=80~160 大=200~400 ThreadsPerChild      25#Max設定:小建議設定:小=10000 中或大=10000~50000(此外,如果MaxClients/ThreadsPerChild大於16,還需額外設定ServerLimit參數,ServerLimit必須大於等於MaxClients/ThreadsPerChild 的值。參數作用如下:

StartServers

啟動Apache時所建立的子程序數。

MinSpareServers

處於空閒狀態的最小子程序數。

所謂空閒子程序是指沒有正在處理請求的子程序。如果目前空閒子程序數少於MinSpareServers,那麼Apache將以最大每秒一個的速度產生新的子程序。只有在非常繁忙機器上才需要調整這個參數。此值不宜過大。

MaxSpareServers

處於空閒狀態的最大子行程數。

只有在非常繁忙機器上才需要調整這個參數。此值不宜過大。如果你將該指令的值設定為比MinSpareServers小,Apache將會自動將其修改成MinSpareServers 1。

MaxClients

允許同時連線的最大請求數量。

任何超過MaxClients限制的請求都會進入等待佇列,直到達到ListenBacklog指令限制的最大值為止。

對於非執行緒型的MPM(也就是mpm_prefork),MaxClients表示可以用來處理客戶端請求的最大子程序數量,預設值是256。要增大這個值,你必須同時增大ServerLimit。

對於執行緒型或混合型的MPM(也就是mpm_beos或mpm_worker),MaxClients表示可以用來處理客戶端請求的最大執行緒數。線程型的mpm_beos的預設值是50。對於混合型的MPM預設值是16(ServerLimit)乘以25(ThreadsPerChild)的結果。因此要將MaxClients增加到超過16個進程才能提供的時候,你必須同時增加ServerLimit的值。

MinSpareThreads

處於空閒狀態的最小執行緒數。

不同的MPM對這個指令的處理是不一樣的:

mpm_worker的預設值是75。這個MPM將基於整個伺服器監視空閒線程數。如果伺服器中總的空閒執行緒數太少,子行程將產生新的空閒執行緒。 mpm_netware的預設值是10。既然這個MPM只運行單獨一個子進程,此MPM當然也是基於整個伺服器監視空閒執行緒數。 mpm_beos和mpmt_os2的工作方式與mpm_netware差不多,mpm_beos的預設值是1;mpmt_os2的預設值是5。

MaxSpareThreads

處於空閒狀態的最大執行緒數。

不同的MPM對這個指令的處理是不一樣的:

mpm_worker的預設值是250。這個MPM將基於整個伺服器監視空閒線程數。如果伺服器中總的空閒執行緒數太多,子行程將殺死多餘的空閒執行緒。 mpm_netware的預設值是100。既然這個MPM只運行單獨一個子進程,此MPM當然也是基於整個伺服器監視空閒執行緒數。 mpm_beos和mpmt_os2的工作方式與mpm_netware差不多,mpm_beos的預設值是50;mpmt_os2的預設值是10。

備註:ServerLimit表示Apache允許建立的最大進程數。值得注意的是,Apache在編譯時內部有一個硬限制ServerLimit 20000(對於mpm_prefork模組為ServerLimit 200000)。你不能超越這個限制。

使用這個指令時要特別當心。如果將ServerLimit設定成一個高出實際需要許多的值,將會有過多的共享記憶體被分配。如果將ServerLimit和MaxClients設定成超過系統的處理能力,Apache可能無法啟動,或者係統將變得不穩定。

注意:在配置相關參數時,請先確保伺服器具備足夠的硬體效能(例如:CPU、記憶體等)。如果發現自啟動後,隨著伺服器的運行時間增加,伺服器的記憶體佔用也隨之增加,可能是程式中出現記憶體洩露,請向下調整參數MaxRequestsPerChild的值以降低記憶體外洩帶來的影響,然後儘快找出程式中的問題之所在。

以上是apache修改最大並發連線數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jianshu.com。如有侵權,請聯絡admin@php.cn刪除