php-fpm的起動

來源:互聯網
上載者:User
php-fpm的啟動

?????? php 5.3.3 源碼中開始包含 php-fpm,不用專門再打補丁了,只需要解開源碼直接configure,關於php-fpm的編譯參數有 –enable-fpm –with-fpm-user=www –with-fpm-group=www –with-libevent-dir=libevent位置。

?

這個php-fpm 不再支援 php-fpm 補丁具有的 /usr/local/php/sbin/php-fpm (start|stop|reload)等命令,需要使用訊號控制:

?

master進程可以理解以下訊號

?

SIGINT, SIGTERM 立刻終止
SIGQUIT 平滑終止
SIGUSR1 重新開啟記錄檔
SIGUSR2 平滑重載所有worker進程並重新載入配置和二進位模組

?

樣本:
php-fpm 關閉:
kill -SIGINT `cat /usr/local/php/var/run/php-fpm.pid`
php-fpm 重啟:
kill -SIGUSR2 `cat /usr/local/php/var/run/php-fpm.pid`

?

其次設定檔不再使用的xml 格式,改為了INI,但是配置參數幾乎和以前一樣,可參照xml格式的格式配置。

?

—————-補充內容—————-
php-fpm的啟動:

?

cp -f (php -5.3.x-source-dir)/sapi/fpm/init.d.php-fpm /etc/init.d/php-fpmchmod 755 /etc/init.d/php-fpm/etc/init.d/php-fpm start/sbin/chkconfig --add php-fpm (添加到開機服務列表)/sbin/chkconfig php-fpm on

?

php-fpm的啟動、停止和重啟:
/etc/init.d/php-fpm start
/etc/init.d/php-fpm stop
/etc/init.d/php-fpm reload

----參考http://ideas.spkcn.com/technology/php-technology/133.html-------------------------------------------

?

?

?

約定幾個目錄
/usr/local/php/sbin/php-fpm
/usr/local/php/etc/php-fpm.conf
/usr/local/php/etc/php.ini

?

?

#測試php-fpm配置/usr/local/php/sbin/php-fpm -t/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm.conf -t #啟動php-fpm/usr/local/php/sbin/php-fpm/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini -y /usr/local/php/etc/php-fpm.conf #關閉php-fpmkill -INT `cat /usr/local/php/var/run/php-fpm.pid` #重啟php-fpmkill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`

?

二,php-fpm.conf重要參數詳解

?

pid = run/php-fpm.pid#pid設定,預設在安裝目錄中的var/run/php-fpm.pid,建議開啟 error_log = log/php-fpm.log#錯誤記錄檔,預設在安裝目錄中的var/log/php-fpm.log log_level = notice#錯誤層級. 可用層級為: alert(必須立即處理), error(錯誤情況), warning(警告情況), notice(一般重要訊息), debug(調試資訊). 預設: notice. emergency_restart_threshold = 60emergency_restart_interval = 60s#表示在emergency_restart_interval所設值內出現SIGSEGV或者SIGBUS錯誤的php-cgi進程數如果超過 emergency_restart_threshold個,php-fpm就會優雅重啟。這兩個選項一般保持預設值。 process_control_timeout = 0#設定子進程接受主進程複用訊號的逾時時間. 可用單位: s(秒), m(分), h(小時), 或者 d(天) 預設單位: s(秒). 預設值: 0. daemonize = yes#後台執行fpm,預設值為yes,如果為了調試可以改為no。在FPM中,可以使用不同的設定來運行多個進程池。 這些設定可以針對每個進程池單獨設定。 listen = 127.0.0.1:9000#fpm監聽連接埠,即nginx中php處理的地址,一般預設值即可。可用格式為: 'ip:port', 'port', '/path/to/unix/socket'. 每個進程池都需要設定. listen.backlog = -1#backlog數,-1表示無限制,由作業系統決定,此行注釋掉就行。backlog含義參考:http://www.3gyou.cc/?p=41 listen.allowed_clients = 127.0.0.1#允許訪問FastCGI進程的IP,設定any為不限制IP,如果要設定其他主機的nginx也能訪問這台FPM進程,listen處要設定成本地可被訪問的IP。預設值是any。每個地址是用逗號分隔. 如果沒有設定或者為空白,則允許任何伺服器請求串連 listen.owner = wwwlisten.group = wwwlisten.mode = 0666#unix socket設定選項,如果使用tcp方式訪問,這裡注釋即可。 user = wwwgroup = www#啟動進程的帳戶和組 pm = dynamic #對於專用伺服器,pm可以設定為static。#如何控制子進程,選項有static和dynamic。如果選擇static,則由pm.max_children指定固定的子進程數。如果選擇dynamic,則由下開參數決定:pm.max_children #,子進程最大數pm.start_servers #,啟動時的進程數pm.min_spare_servers #,保證空閑進程數最小值,如果空閑進程小於此值,則建立新的子進程pm.max_spare_servers #,保證空閑進程數最大值,如果空閑進程大於此值,此進行清理 pm.max_requests = 1000#設定每個子進程重生之前服務的請求數. 對於可能存在記憶體流失的第三方模組來說是非常有用的. 如果設定為 '0' 則一直接受請求. 等同於 PHP_FCGI_MAX_REQUESTS 環境變數. 預設值: 0. pm.status_path = /status#FPM狀態頁面的網址. 如果沒有設定, 則無法訪問狀態頁面. 預設值: none. munin監控會使用到 ping.path = /ping#FPM監控頁面的ping網址. 如果沒有設定, 則無法訪問ping頁面. 該頁面用於外部檢測FPM是否存活並且可以響應請求. 請注意必須以斜線開頭 (/)。 ping.response = pong#用於定義ping請求的返回相應. 返回為 HTTP 200 的 text/plain 格式文本. 預設值: pong. request_terminate_timeout = 0#設定單個請求的逾時中止時間. 該選項可能會對php.ini設定中的'max_execution_time'因為某些特殊原因沒有中止啟動並執行指令碼有用. 設定為 '0' 表示 'Off'.當經常出現502錯誤時可以嘗試更改此選項。 request_slowlog_timeout = 10s#當一個請求該設定的逾時時間後,就會將對應的PHP呼叫堆疊資訊完整寫入到慢日誌中. 設定為 '0' 表示 'Off' slowlog = log/$pool.log.slow#慢請求的記錄日誌,配合request_slowlog_timeout使用 rlimit_files = 1024#設定檔案開啟描述符的rlimit限制. 預設值: 系統定義值預設可開啟控制代碼是1024,可使用 ulimit -n查看,ulimit -n 2048修改。 rlimit_core = 0#設定核心rlimit最大限制值. 可用值: 'unlimited' 、0或者正整數. 預設值: 系統定義值. chroot =#啟動時的Chroot目錄. 所定義的目錄需要是絕對路徑. 如果沒有設定, 則chroot不被使用. chdir =#設定啟動目錄,啟動時會自動Chdir到該目錄. 所定義的目錄需要是絕對路徑. 預設值: 目前的目錄,或者/目錄(chroot時) catch_workers_output = yes#重新導向運行過程中的stdout和stderr到主要的錯誤記錄檔檔案中. 如果沒有設定, stdout 和 stderr 將會根據FastCGI的規則被重新導向到 /dev/null . 預設值: 空.

?參考:http://www.4wei.cn/archives/1002061

?

?

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.