摘要:?jiǎn)?dòng)之后,會(huì)創(chuàng)建一個(gè)進(jìn)程,監(jiān)聽(tīng)端口可配置,進(jìn)程又會(huì)根據(jù)去創(chuàng)建若干子進(jìn)程,子進(jìn)程用于處理實(shí)際的業(yè)務(wù)。如果選擇,則由指定固定的子進(jìn)程數(shù)。
FPM工作流程
fpm 全名是FastCGI進(jìn)程管理器,可以參考關(guān)于FastCGI的說(shuō)明:CGI、FastCGI、PHP-CGI和PHP-FPM 概念區(qū)分
fpm啟動(dòng)后會(huì)先讀php.ini,然后再讀取相應(yīng)的conf配置文件,conf配置可以覆蓋php.ini的配置。啟動(dòng)fpm之后,會(huì)創(chuàng)建一個(gè)master進(jìn)程,監(jiān)聽(tīng)9000端口(可配置),master進(jìn)程又會(huì)根據(jù)fpm.conf/www.conf去創(chuàng)建若干子進(jìn)程,子進(jìn)程用于處理實(shí)際的業(yè)務(wù)。當(dāng)有客戶端(比如nginx)來(lái)連接9000端口時(shí),空閑子進(jìn)程會(huì)自己去accept,如果子進(jìn)程全部處于忙碌狀態(tài),新進(jìn)的待accept的連接會(huì)被master放進(jìn)隊(duì)列里,等待fpm子進(jìn)程空閑;這個(gè)存放待accept的半連接的隊(duì)列有多長(zhǎng),由 listen.backlog 配置。
#測(cè)試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 #啟動(dòng)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 #關(guān)閉php-fpm kill -INT `cat /usr/local/php/var/run/php-fpm.pid` #重啟php-fpm kill -USR2 `cat /usr/local/php/var/run/php-fpm.pid`php-fpm.conf重要參數(shù)詳解
pid = run/php-fpm.pid #pid設(shè)置,默認(rèn)在安裝目錄中的var/run/php-fpm.pid,建議開(kāi)啟 error_log = log/php-fpm.log #錯(cuò)誤日志,默認(rèn)在安裝目錄中的var/log/php-fpm.log 如果設(shè)置為syslog,log就會(huì)發(fā)送給syslogd服務(wù)而不會(huì)寫進(jìn)文件里。 syslog.facility = daemon # 把日志寫進(jìn)系統(tǒng)log,linux還不夠熟悉,暫時(shí)不用理會(huì)。 syslog.ident = php-fpm #系統(tǒng)日志標(biāo)示,如果跑了多個(gè)fpm進(jìn)程,需要用這個(gè)來(lái)區(qū)分日志是誰(shuí)的。 log_level = notice #錯(cuò)誤級(jí)別. 可用級(jí)別為: alert(必須立即處理), error(錯(cuò)誤情況), warning(警告情況), notice(一般重要信息), debug(調(diào)試信息). 默認(rèn): notice. emergency_restart_threshold = 60 emergency_restart_interval = 60s #表示在emergency_restart_interval所設(shè)值內(nèi)出現(xiàn)SIGSEGV或者SIGBUS錯(cuò)誤的php-cgi進(jìn)程數(shù)如果超過(guò) emergency_restart_threshold個(gè),php-fpm就會(huì)優(yōu)雅重啟。這兩個(gè)選項(xiàng)一般保持默認(rèn)值。 process_control_timeout = 0 #設(shè)置子進(jìn)程接受主進(jìn)程復(fù)用信號(hào)的超時(shí)時(shí)間. 可用單位: s(秒), m(分), h(小時(shí)), 或者 d(天) 默認(rèn)單位: s(秒). 默認(rèn)值: 0. daemonize = yes #后臺(tái)執(zhí)行fpm,默認(rèn)值為yes,如果為了調(diào)試可以改為no。在FPM中,可以使用不同的設(shè)置來(lái)運(yùn)行多個(gè)進(jìn)程池。 這些設(shè)置可以針對(duì)每個(gè)進(jìn)程池多帶帶設(shè)置。 listen = 127.0.0.1:9000 #fpm監(jiān)聽(tīng)端口,即nginx中php處理的地址,一般默認(rèn)值即可。可用格式為: "ip:port", "port", "/path/to/unix/socket". 每個(gè)進(jìn)程池都需要設(shè)置. listen.backlog = -1 #未accept處理的socket隊(duì)列大小,-1 on FreeBSD and OpenBSD,其他平臺(tái)默認(rèn)65535,高并發(fā)時(shí)重要,合理設(shè)置會(huì)及時(shí)處理排隊(duì)的請(qǐng)求;太大會(huì)積壓太多,處理完后nginx在前面都等超時(shí)斷開(kāi)這個(gè)和fpm的socket連接了,就杯具了。不要用-1,建議1024以上,最好是2的冪值。 # 一個(gè)池共用一個(gè)backlog隊(duì)列,所有的池進(jìn)程都去這個(gè)隊(duì)列里accept連接。 # 最大數(shù)量受限于系統(tǒng)配置 cat /proc/sys/net/core/somaxconn,系統(tǒng)配置修改:vim /etc/sysctl.conf,增加 net.core.somaxconn = 2000 則最大為2000,然后php最大的backlog可以到2000。 listen.allowed_clients = 127.0.0.1 #允許訪問(wèn)FastCGI進(jìn)程的IP,設(shè)置any為不限制IP,如果要設(shè)置其他主機(jī)的nginx也能訪問(wèn)這臺(tái)FPM進(jìn)程,listen處要設(shè)置成本地可被訪問(wèn)的IP。默認(rèn)值是any。每個(gè)地址是用逗號(hào)分隔. 如果沒(méi)有設(shè)置或者為空,則允許任何服務(wù)器請(qǐng)求連接 listen.owner = www listen.group = www listen.mode = 0666 #unix socket設(shè)置選項(xiàng),如果使用tcp方式訪問(wèn),這里注釋即可。 user = www group = www #啟動(dòng)進(jìn)程的帳戶和組 pm = dynamic #對(duì)于專用服務(wù)器,pm可以設(shè)置為static。 #如何控制子進(jìn)程,選項(xiàng)有static和dynamic。如果選擇static,則由pm.max_children指定固定的子進(jìn)程數(shù)。如果選擇dynamic,則由下開(kāi)參數(shù)決定: pm.max_children #,子進(jìn)程最大數(shù) pm.start_servers #,啟動(dòng)時(shí)的進(jìn)程數(shù) pm.min_spare_servers #,保證空閑進(jìn)程數(shù)最小值,如果空閑進(jìn)程小于此值,則創(chuàng)建新的子進(jìn)程 pm.max_spare_servers #,保證空閑進(jìn)程數(shù)最大值,如果空閑進(jìn)程大于此值,此進(jìn)行清理 pm.max_requests = 1000 #設(shè)置每個(gè)子進(jìn)程重生之前服務(wù)的請(qǐng)求數(shù). 對(duì)于可能存在內(nèi)存泄漏的第三方模塊來(lái)說(shuō)是非常有用的. 如果設(shè)置為 "0" 則一直接受請(qǐng)求. 等同于 PHP_FCGI_MAX_REQUESTS 環(huán)境變量. 默認(rèn)值: 0. pm.status_path = /status #FPM狀態(tài)頁(yè)面的網(wǎng)址. 如果沒(méi)有設(shè)置, 則無(wú)法訪問(wèn)狀態(tài)頁(yè)面. 默認(rèn)值: none. munin監(jiān)控會(huì)使用到 ping.path = /ping #FPM監(jiān)控頁(yè)面的ping網(wǎng)址. 如果沒(méi)有設(shè)置, 則無(wú)法訪問(wèn)ping頁(yè)面. 該頁(yè)面用于外部檢測(cè)FPM是否存活并且可以響應(yīng)請(qǐng)求. 請(qǐng)注意必須以斜線開(kāi)頭 (/)。 ping.response = pong #用于定義ping請(qǐng)求的返回相應(yīng). 返回為 HTTP 200 的 text/plain 格式文本. 默認(rèn)值: pong. request_terminate_timeout = 0 #設(shè)置單個(gè)請(qǐng)求的超時(shí)中止時(shí)間. 該選項(xiàng)可能會(huì)對(duì)php.ini設(shè)置中的"max_execution_time"因?yàn)槟承┨厥庠驔](méi)有中止運(yùn)行的腳本有用. 設(shè)置為 "0" 表示 "Off".當(dāng)經(jīng)常出現(xiàn)502錯(cuò)誤時(shí)可以嘗試更改此選項(xiàng)。 request_slowlog_timeout = 10s #當(dāng)一個(gè)請(qǐng)求該設(shè)置的超時(shí)時(shí)間后,就會(huì)將對(duì)應(yīng)的PHP調(diào)用堆棧信息完整寫入到慢日志中. 設(shè)置為 "0" 表示 "Off" slowlog = log/$pool.log.slow #慢請(qǐng)求的記錄日志,配合request_slowlog_timeout使用 rlimit_files = 1024 #設(shè)置文件打開(kāi)描述符的rlimit限制. 默認(rèn)值: 系統(tǒng)定義值默認(rèn)可打開(kāi)句柄是1024,可使用 ulimit -n查看,ulimit -n 2048修改。 rlimit_core = 0 #設(shè)置核心rlimit最大限制值. 可用值: "unlimited" 、0或者正整數(shù). 默認(rèn)值: 系統(tǒng)定義值. chroot = #啟動(dòng)時(shí)的Chroot目錄. 所定義的目錄需要是絕對(duì)路徑. 如果沒(méi)有設(shè)置, 則chroot不被使用. chdir = #設(shè)置啟動(dòng)目錄,啟動(dòng)時(shí)會(huì)自動(dòng)Chdir到該目錄. 所定義的目錄需要是絕對(duì)路徑. 默認(rèn)值: 當(dāng)前目錄,或者/目錄(chroot時(shí)) catch_workers_output = yes #重定向運(yùn)行過(guò)程中的stdout和stderr到主要的錯(cuò)誤日志文件中. 如果沒(méi)有設(shè)置, stdout 和 stderr 將會(huì)根據(jù)FastCGI的規(guī)則被重定向到 /dev/null . 默認(rèn)值: 空fpm進(jìn)程狀態(tài)監(jiān)控
1、nginx配置:遇到 status 的請(qǐng)求,直接轉(zhuǎn)發(fā)給php
2、fpm配置:pm.status_path = /status
3、然后重新fpm和nginx,在瀏覽器里訪問(wèn)就能看到了:
默認(rèn)以?text/plain?展示結(jié)果,可以傳參數(shù)??json/html/xml?分別得到j(luò)son等格式的結(jié)果;參數(shù)full可以查看每個(gè)子進(jìn)程的明細(xì)
pool?進(jìn)程池名稱
process manager?進(jìn)程管理方式
start time?進(jìn)程什么時(shí)候啟動(dòng)的
start since?進(jìn)程已經(jīng)運(yùn)行了多少秒
accepted conn?該池總共accept了多少連接
listen queue?等待accept的連接的數(shù)量
max listen queue fpm啟動(dòng)后,歷史最高等待accept的連接的數(shù)量
listen queue len?配置的監(jiān)聽(tīng)隊(duì)列最大長(zhǎng)度?受限于listen.backlog和系統(tǒng)cat /proc/sys/net/core/somaxconn,兩者中取最小值
idle processes?閑置的進(jìn)程數(shù)
active process?正在工作的進(jìn)程數(shù)(加上限制的,就是總的子進(jìn)程數(shù))
total processes?總的子進(jìn)程數(shù)量
max active processes fpm啟動(dòng)后,歷史最多同時(shí)工作的進(jìn)程數(shù)
max children reached?進(jìn)程管理模式為?"dynamic"和?"ondemand"時(shí),此數(shù)值是當(dāng)子進(jìn)程不夠用時(shí),master創(chuàng)建更多子進(jìn)程的次數(shù)
slow requests?慢請(qǐng)求個(gè)數(shù)
full參數(shù)下
pid?子進(jìn)程ID;
state?子進(jìn)程狀態(tài)(Idle,?Running,?...);
start time?子進(jìn)程啟動(dòng)的時(shí)間;
start since?子進(jìn)程啟動(dòng)后運(yùn)行了多少秒;
requests?當(dāng)前子進(jìn)程一共處理了多少個(gè)請(qǐng)求;
request duration?請(qǐng)求耗費(fèi)的納秒數(shù);
request method?請(qǐng)求方法?(GET,?POST,?...);
request URI?請(qǐng)求參數(shù);
content length POST請(qǐng)求時(shí),請(qǐng)求的內(nèi)容長(zhǎng)度;
user?-?the user?(PHP_AUTH_USER)?(or?"-"?if?not?set);
script?請(qǐng)求的哪個(gè)php文件;
last?request cpu?上次請(qǐng)求耗費(fèi)的cpu資源
last?request memory?上次請(qǐng)求耗費(fèi)的內(nèi)存峰值
如果進(jìn)程是閑置狀態(tài),那這些信息記錄的就是上次請(qǐng)求的相關(guān)數(shù)據(jù),否則就是當(dāng)前本次請(qǐng)求的相關(guān)數(shù)據(jù)。
參考:http://www.cnblogs.com/52php/...
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/30563.html
摘要:同樣,如果有之類的,也是由于慢查詢導(dǎo)致的參考鏈接配置 環(huán)境說(shuō)明 root@ubuntu:/home/tb# cat /etc/issue Ubuntu 16.04.2 LTS l root@ubuntu:/home/tb# php -v PHP 7.0.15-0ubuntu0.16.04.4 (cli) ( NTS ) Copyright (c) 1997-2017 The PH...
摘要:是本地文件的存儲(chǔ)目錄,是容器內(nèi)文件的存儲(chǔ)目錄,表示只讀。編輯配置文件本地存儲(chǔ)路徑配置文件內(nèi)容說(shuō)明表示服務(wù)的,下文還會(huì)提及。訪問(wèn)時(shí),讓執(zhí)行,這個(gè)路徑經(jīng)轉(zhuǎn)換成。 看完 docker 官方教程,想搭個(gè)本地 php 開(kāi)發(fā)環(huán)境,可搜了一圈,也沒(méi)找到特別滿意的文章,順手總結(jié)一個(gè)。 假設(shè) 你知道 nginx、php-fpm 是什么 你了解 docker 的基本命令 運(yùn)行環(huán)境 MacBook Pr...
摘要:是本地文件的存儲(chǔ)目錄,是容器內(nèi)文件的存儲(chǔ)目錄,表示只讀。編輯配置文件本地存儲(chǔ)路徑配置文件內(nèi)容說(shuō)明表示服務(wù)的,下文還會(huì)提及。訪問(wèn)時(shí),讓執(zhí)行,這個(gè)路徑經(jīng)轉(zhuǎn)換成。 看完 docker 官方教程,想搭個(gè)本地 php 開(kāi)發(fā)環(huán)境,可搜了一圈,也沒(méi)找到特別滿意的文章,順手總結(jié)一個(gè)。 假設(shè) 你知道 nginx、php-fpm 是什么 你了解 docker 的基本命令 運(yùn)行環(huán)境 MacBook Pr...
摘要:是本地文件的存儲(chǔ)目錄,是容器內(nèi)文件的存儲(chǔ)目錄,表示只讀。編輯配置文件本地存儲(chǔ)路徑配置文件內(nèi)容說(shuō)明表示服務(wù)的,下文還會(huì)提及。訪問(wèn)時(shí),讓執(zhí)行,這個(gè)路徑經(jīng)轉(zhuǎn)換成。 看完 docker 官方教程,想搭個(gè)本地 php 開(kāi)發(fā)環(huán)境,可搜了一圈,也沒(méi)找到特別滿意的文章,順手總結(jié)一個(gè)。 假設(shè) 你知道 nginx、php-fpm 是什么 你了解 docker 的基本命令 運(yùn)行環(huán)境 MacBook Pr...
摘要:進(jìn)程數(shù)的配置會(huì)奏效會(huì)自動(dòng)增加數(shù)但是性能提升效果并不明顯然而的并沒(méi)奏效,仍然只有一個(gè)通過(guò)手動(dòng)增加配置發(fā)現(xiàn)有所提升但效果很不明顯。于是我更改了的配置改為再次結(jié)果能達(dá)到左右差不多翻倍了結(jié)論性能問(wèn)題并不那么容易解決需要耐心的排查原因 一直知道nginx本身能進(jìn)行負(fù)載均衡,但沒(méi)有測(cè)試過(guò),今天實(shí)驗(yàn)了下,以下是筆記記錄 showImg(https://segmentfault.com/img/rem...
閱讀 840·2023-04-25 19:49
閱讀 3771·2021-09-30 09:47
閱讀 2768·2021-09-13 10:21
閱讀 2695·2021-08-24 10:04
閱讀 3183·2019-08-30 15:55
閱讀 2332·2019-08-30 15:55
閱讀 2414·2019-08-30 15:54
閱讀 3481·2019-08-30 13:53