<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    歡迎使用我的 在線工具

    小D

    讀歷史、看小說、寫程序都是我所愛。技術不好,頭腦不靈光,靠的是興趣。
    隨筆 - 35, 文章 - 25, 評論 - 13, 引用 - 0
    數據加載中……

    apache2.2.11最大連接數配置(轉載)

    apache2.2.11最大連接數配置(轉載)

    每次重做服務器,就會學到一些新的東西,所以了解linux最簡潔有效的辦法,就是不停的重做系統,重新配置優化系統(XD!)。
    本次使用了apache2.2.6,編譯完成后,最大連接數默認為150,運行一段時間后出現大量的CLOSE_WAIT,于是修改默認連接數。apache2.2以后許多功能都抽出來單獨存放了,在http.conf里進行引用。存儲連接數等相關指令的文件是httpd-mpm.conf,apache采用的是prefork模式來進行連接數量方面的控制,prefork模塊的格式如下:
    <ifmodule mpm_prefork_module>
    StartServers 5
    MinSpareServers 5
    MaxSpareServers 10
    MaxClients 150
    MaxRequestsPerChild 0<ifmodule>

    其工作原理如下:
    控制進程在最初建立StartServers個子進程后, 為了滿足MinSpareServers設置的需要,創建一個進程,等待一秒鐘,繼續創建第二個,等待一秒鐘,繼而創建四個,如此按指數級增加創建的進程 數,最多達到每秒32個,直到滿足MinSpareServers設置的值為止,這也就是預派生(prefork)的由來。這種模式可以使得不必在請求到 來時再產生新的進程,從而減小了系統開銷以增加性能。
    MaxSpareServers 設置了最大的空閑進程數,如果空閑進程數大于這個值,Apache會自動kill某些多余進程。這個值一般不要設的過大,但如果設的比 MinSpareServers小,Apache會自動把它調整為MinSpareServers+1。如果站點負載較大的話,可考慮同時加大 MinSpareServers和MaxSpareServers。
    MaxRequestsPerChild設置的是每個子進程可以 處理的請求數。每個子進程在處理了MaxRequestsPerChild個請求后將自動銷毀。0意味著無限,即子進程永不銷毀。雖然缺省設為0可以使每 個子進程處理更多的請求,但如果設成非零值也有兩點重要的好處:
    1. 可防止意外的內存卸漏;
    2. 在服務器負載下降的時侯會自動減少子進程數。
    因此,可根據服務器的負載來調整這個值,如果非零的話,筆者認為10000左右是比較合適的。事實上這個值對Apache的性能影響不是很大。
    MaxClients 是這些指令中最為重要的一個,它設定的就是Apache可以同時處理的請求,這是對Apache性能影響最大的參數.在我個人看來,缺省的150是遠遠不 夠的,如果請求總數已達到這個值(可通過ps –ef|grep httpd|wc –l來確認),那么下面的請求就要排隊,直到某個已處理請求完畢。這就是為什么系統資源還剩下很多,而http訪問卻很慢的主要原因。系統管理員可以根據 硬件配置和負載情況來動態調整這個值,雖然理論上這個值越大,可以處理的請求就越多,但Apache默認的限制是不能大于256。如果把這個值設為大于 256那么Apache將無法起動。事實上,256對于負載稍重的站點也是很不夠的。在Apache1.3中這是個硬限制,如果要加大這個值,必須在 configure前手工修改源代碼樹下的src/include/httpd.h,查找256,會發現#define HARD_SERVER_LIMIT 256這行,把256改為你要增大的值如4000,然后重新編譯Apache即可。我想這個方法稍有些經驗的Apache系統管理員都知道,不過我相信在 Apache2.0中知道如何加大這個值的人就不會太多了。
    在Apache2.0中新加入了ServerLimit指令,使得無須重編譯Apache就可以加大MaxClients。下面是筆者的prefork配置段。
    <IfModule prefork.c>
    StartServers 10
    MinSpareServers 10
    MaxSpareServers 15
    ServerLimit 2000
    MaxClients 1500
    MaxRequestsPerChild 10000
    </IfModule>
    BTW: ServerLimit的最大值是20000,這對于大多數站點是足夠了,但如果你一定要再加大的話,那么這個值位于源代碼樹下的server/mpm/prefork/prefork.c中。里面的
    #define DEFAULT_SERVER_LIMIT 256
    #define MAX_SERVER_LIMIT 20000
    這兩行就對應著MaxClients和ServerLimit的限制值。 但我相信很少有人可以用到20000的并發連接數。
    以上內容來自unix中文 對于prefork的工作模式能夠實現的功能描寫的比較詳盡了。我在用的時候發現ServerLimits和MaxClients這兩個參數的順序是不可以顛倒的,否則重起apache時會報警。根據周超 同學的提醒,凡是有依賴關系的命令,書寫應該都是有順序的。
    同時在查資料的過程中,揀到一條命令:
    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表示處理完畢,等待超時結束的請求數。
    返回的結果非常簡潔直接,就是句子有點長 -_-。
    原文來自51CTO技術論壇

    posted on 2011-10-17 14:12 vagasnail 閱讀(855) 評論(0)  編輯  收藏


    只有注冊用戶登錄后才能發表評論。


    網站導航:
     
    主站蜘蛛池模板: 五级黄18以上免费看| 亚洲综合偷自成人网第页色| 春意影院午夜爽爽爽免费| 四虎影永久在线高清免费| 亚洲AV永久无码精品一福利| 免费观看理论片毛片| 色偷偷亚洲第一综合| 亚洲精品国产精品乱码不卞| 午夜免费国产体验区免费的| 国产亚洲精久久久久久无码77777 国产亚洲精品成人AA片新蒲金 | 91麻豆最新在线人成免费观看| 色婷婷亚洲十月十月色天| 久久久精品2019免费观看| 亚洲乱码一二三四区国产| 国内自产拍自a免费毛片| 色九月亚洲综合网| 久久亚洲精品无码观看不卡| 国产成人无码区免费网站| 亚洲一区综合在线播放| 九九精品免费视频| 日韩色视频一区二区三区亚洲| 亚洲性久久久影院| 95免费观看体验区视频| 亚洲综合在线一区二区三区| 成人亚洲网站www在线观看| 本免费AV无码专区一区| 亚洲精品在线免费观看视频| 成年女人毛片免费视频| 一本久久免费视频| 亚洲AV第一页国产精品| 大香人蕉免费视频75| 国产精品美女免费视频观看| 亚洲视频在线一区二区三区| 在线视频免费国产成人| 中国videos性高清免费| 亚洲乱码卡一卡二卡三| 国产成人精品日本亚洲专区61| av无码久久久久不卡免费网站| 国产青草亚洲香蕉精品久久| 亚洲avav天堂av在线不卡| 国产成人3p视频免费观看|