校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > apache中并發控制參數prefork理解和調優

apache中并發控制參數prefork理解和調優

熱門標簽:江蘇客服外呼系統怎么樣 灰谷地圖標注 平頂山手機自動外呼系統違法嗎 南寧銷售電銷機器人廠家 省份地圖標注 科研地圖標注 地圖標注軌跡 陽江智能電銷機器人 辦理400電話怎么劃傷
一個apache有linux下的并發不是很高的,大約到3K的樣子,普通的服務器都會不同程度的出現問題.apache有關并發控制主要是 prefork和worker二個其中一個來控制.我們可以使用httpd -l來確定當前使用的MPM是prefork.c,還是Worker.c.下面是apache中有關prefork的配置.下面是我優化過的參數.
IfModule prefork.c>
#有這個參數就不必像apache1一樣修改源碼才能修改256客戶數的限制,聽講要放到最前面才會生效,2000是這個參數的最大值
ServerLimit 2000
#指定服務器啟動時建立的子進程數量,prefork默認為5。
StartServers 25
#指定空閑子進程的最小數量,默認為5。如果當前空閑子進程數少于MinSpareServers ,那么Apache將以最大每秒一個的速度產生新的子進程。此參數不要設的太大。
MinSpareServers 25
#設置空閑子進程的最大數量,默認為10。如果當前有超過MaxSpareServers數量的空閑子進程,那么父進程將殺死多余的子進程。此參數 不要設的太大。如果你將該指令的值設置為比MinSpareServers小,Apache將會自動將其修改成"MinSpareServers+1"。
MaxSpareServers 50
#限定同一時間客戶端最大接入請求的數量(單個進程并發線程數),默認為256。任何超過MaxClients限制的請求都將進入等候隊列,一旦一個鏈接被釋放,隊列中的請求將得到服務。要增大這個值,你必須同時增大ServerLimit 。
MaxClients 2000
#每個子進程在其生存期內允許伺服的最大請求數量,默認為10000.到達MaxRequestsPerChild的限制后,子進程將會結束。如果MaxRequestsPerChild為"0",子進程將永遠不會結束。
MaxRequestsPerChild 10000
/IfModule>
將MaxRequestsPerChild設置成非零值有兩個好處:
1.可以防止(偶然的)內存泄漏無限進行,從而耗盡內存。
2.給進程一個有限壽命,從而有助于當服務器負載減輕的時候減少活動進程的數量。
工作方式:
一個單獨的控制進程(父進程)負責產生子進程,這些子進程用于監聽請求并作出應答。Apache總是試圖保持一些備用的 (spare)或者是空閑的子進程用于迎接即將到來的請求。這樣客戶端就不需要在得到服務前等候子進程的產生。在Unix系統中,父進程通常以root身 份運行以便邦定80端口,而 Apache產生的子進程通常以一個低特權的用戶運行。User和Group指令用于設置子進程的低特權用戶。運行子進程的用戶必須要對它所服務的內容有 讀取的權限,但是對服務內容之外的其他資源必須擁有盡可能少的權限。
我們調優常常要查看httpd進程數(即prefork模式下Apache能夠處理的并發請求數):
#ps -ef | grep httpd | wc -l
出現的結果,就是當前Apache能夠處理的多少個并發請求,這個值Apache根據負載情況自動調.
查看Apache的并發請求數及其TCP連接狀態:
#netstat -n | awk ‘/^tcp/ {++S[$NF]} END {for(a in S) print a, S[a]}’
上面這句來自己我一個新浪的朋友張宴.
返回結果示例:
LAST_ACK 5
SYN_RECV 30
ESTABLISHED 1597
FIN_WAIT1 51
FIN_WAIT2 504
TIME_WAIT 1057
其中的SYN_RECV表示正在等待處理的請求數;ESTABLISHED表示正常數據傳輸狀態;TIME_WAIT表示處理完畢,等待超時結束的請求數。
狀態:描述
CLOSED:無連接是活動的或正在進行
LISTEN:服務器在等待進入呼叫
SYN_RECV:一個連接請求已經到達,等待確認
SYN_SENT:應用已經開始,打開一個連接
ESTABLISHED:正常數據傳輸狀態
FIN_WAIT1:應用說它已經完成
FIN_WAIT2:另一邊已同意釋放
ITMED_WAIT:等待所有分組死掉
CLOSING:兩邊同時嘗試關閉
TIME_WAIT:另一邊已初始化一個釋放
LAST_ACK:等待所有分組死掉
可以使用Linux下的webbench來作壓力測試.

標簽:通化 瀘州 泰安 儋州 蕪湖 玉樹 玉溪 臨汾

巨人網絡通訊聲明:本文標題《apache中并發控制參數prefork理解和調優》,本文關鍵詞  apache,中,并發,控制,參數,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《apache中并發控制參數prefork理解和調優》相關的同類信息!
  • 本頁收集關于apache中并發控制參數prefork理解和調優的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 霍山县| 肇州县| 元江| 贵阳市| 木兰县| 临夏县| 门源| 双牌县| 永仁县| 炎陵县| 新昌县| 竹溪县| 榆中县| 津市市| 宁远县| 苏尼特左旗| 大连市| 甘德县| 崇仁县| 曲周县| 永修县| 永济市| 景德镇市| 凉城县| 桐乡市| 万安县| 南雄市| 达州市| 原阳县| 永吉县| 手游| 南陵县| 尖扎县| 新巴尔虎左旗| 鸡西市| 鄯善县| 兴隆县| 镶黄旗| 汽车| 那曲县| 兴义市|