国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 網站 > Apache > 正文

令Apache中沉睡的無用進程自動退出的方法

2024-08-27 18:27:26
字體:
來源:轉載
供稿:網友

在Apache的Access Log中會看到很多如下的訪問日志:

    代碼如下:

    127.0.0.1 - - [05/May/2011:10:54:07 +0800] "OPTIONS * HTTP/1.0" 200 -
    127.0.0.1 - - [05/May/2011:10:54:08 +0800] "OPTIONS * HTTP/1.0" 200 -
    127.0.0.1 - - [05/May/2011:10:54:09 +0800] "OPTIONS * HTTP/1.0" 200 -
    127.0.0.1 - - [05/May/2011:10:54:10 +0800] "OPTIONS * HTTP/1.0" 200 -
在Apache Prefork模式下, 啟動的時候,Apache就會fork出一些worker進程, 來準備接受請求, 這些worker進程,在完成準備工作以后, 就會進入block模式的監聽沉睡中, 等待請求到來而被喚醒。

另外一方面, 在Prefork模式下, 當請求很多, 目前的worker進程數不夠處理的時候, 就會額外再fork一些worker進程出來, 以滿足當前的請求。

而在這些請求高峰過后, 如果額外fork出來的進程數大于了MaxSpareServers, Apache就會告訴這些worker進程退出, 那么問題就來了。

這些進程都在沉睡中啊, 怎么告訴他們, 并且讓他們自我退出呢?

Apache會首先發送一個退出狀態字(GRACEFUL_CHAR !)給這些Work進程:

    代碼如下:static apr_status_t pod_signal_internal(ap_pod_t *pod)
    {
        apr_status_t rv;
        char char_of_death = '!';
        apr_size_t one = 1;
    
        rv = apr_file_write(pod->pod_out, &char_of_death, &one);
        if (rv != APR_SUCCESS) {
            ap_log_error(APLOG_MARK, APLOG_WARNING, rv, ap_server_conf,
                         "write pipe_of_death");
        }
    
        return rv;
    }

但此時, Worker進程不會去讀這些狀態字, 因為他們還在沉睡。

這個時候Apache就會發送一個OPTIONS請求給自己, 喚醒這些沉睡的進程:

    代碼如下:static apr_status_t dummy_connection(ap_pod_t *pod)
    {
    //...有省略
        /* Create the request string. We include a User-Agent so that
         * adminstrators can track down the cause of the odd-looking
         * requests in their logs.
         */
        srequest = apr_pstrcat(p, "OPTIONS * HTTP/1.0/r/nUser-Agent: ",

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 南京市| 娄烦县| 长春市| 竹山县| 平凉市| 凉山| 游戏| 获嘉县| 通榆县| 磐石市| 古田县| 锡林浩特市| 灵武市| 巴彦县| 勃利县| 台安县| 交口县| 手游| 普定县| 浦北县| 新巴尔虎右旗| 巨野县| 尖扎县| 永年县| 宜章县| 花莲县| 文登市| 陕西省| 滦平县| 沁阳市| 菏泽市| 徐州市| 无极县| 梨树县| 特克斯县| 英吉沙县| 鄱阳县| 贵州省| 克什克腾旗| 专栏| 且末县|