前言:
成都創(chuàng)新互聯(lián)公司服務(wù)項(xiàng)目包括新豐網(wǎng)站建設(shè)、新豐網(wǎng)站制作、新豐網(wǎng)頁(yè)制作以及新豐網(wǎng)絡(luò)營(yíng)銷(xiāo)策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,新豐網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到新豐省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!最近在騰訊云買(mǎi)了臺(tái)學(xué)生機(jī)打算搭個(gè)博客玩玩,由于空間還在備案中,于是就想著先把環(huán)境(LNMP+phpmyadmin+wordpress)部署好,環(huán)境很順利,但晚上重新連上云服務(wù)器敲命令時(shí)那延時(shí)真是叫一個(gè)痛苦啊,思來(lái)想去覺(jué)得八成是內(nèi)存被耗盡了,于是開(kāi)始排查優(yōu)化之旅
查看內(nèi)存使用情況:
# free -m total used free shared buffers cached Mem: 996 933 63 0 74 268 -/+ buffers/cache: 284 712 Swap: 0 0 0果然,內(nèi)存幾乎被吃盡,看看哪些亂來(lái)的進(jìn)程吃了我的內(nèi)存
# ps -A --sort -rss -o comm,pmem,pcpu |uniq -c |head -10 1 COMMAND %MEM %CPU 1 mysqld 9.1 0.0 1 php-fpm 3.6 0.9 1 php-fpm 3.4 0.9 1 php-fpm 3.4 0.8 1 php-fpm 3.4 0.9 2 php-fpm 3.4 0.8 2 php-fpm 3.4 0.6 1 php-fpm 3.4 0.8 3 php-fpm 3.4 0.9 # ps aux | grep php-fpm |wc -l 22除去以root身份運(yùn)行的作為管理各個(gè)php-fpm進(jìn)程的 master 進(jìn)程與grep進(jìn)程,php-fpm竟然有多達(dá)20個(gè)占用3.4M的php-fpm進(jìn)程
先把mysqld放一邊,我們發(fā)現(xiàn)很大一部分的內(nèi)存都被 php-fpm 進(jìn)程吞了,看來(lái)有必要對(duì) php-fpm 做個(gè)優(yōu)化了
優(yōu)化前,我們有必要了解一下 php-fpm 這個(gè)組件,以及php-fpm在 nginx 環(huán)境下必不可缺的原因
php-fpm:php-FastCGI Process Manager
我們知道apache與php結(jié)合的方式有3種: (找機(jī)會(huì)對(duì)這3種方式做個(gè)詳細(xì)介紹)
1.配置apache,將php解釋器作為cgi腳本
2.將php直接裝載進(jìn)apache模塊
3.使用fastcgi
[注]apache默認(rèn)使用第二種方式
但是,Nginx不支持對(duì)外部程序的直接調(diào)用或者解析,并且Nginx默認(rèn)就不支持cgi模式,所以通常Nginx都是使用 fastcgi 的方式與php結(jié)合
簡(jiǎn)單介紹fast-cgi
fast-cgi在安裝后一旦啟用將 監(jiān)聽(tīng)在TCP的某個(gè)套接字 上,通常表現(xiàn)為 127.0.0.1:9000 ,于是現(xiàn)在客戶端瀏覽器訪問(wèn)一個(gè)動(dòng)態(tài)網(wǎng)頁(yè)(如index.php)時(shí)發(fā)生的行為:nginx將用戶的http請(qǐng)求接進(jìn)來(lái),發(fā)現(xiàn)用戶請(qǐng)求的是一個(gè)php腳本,于是交給fastcgi分析處理,處理完畢后(經(jīng)過(guò)php解釋器解釋與從mysql中取數(shù)據(jù))將結(jié)果回送給nginx,nginx最后將靜態(tài)內(nèi)容返回給客戶端,所以我們能感受到fast-cgi的一大好處是:將動(dòng)態(tài)腳本的解釋過(guò)程從nginx抽出,使得nginx只需專注于與客戶端交互靜態(tài)資源,而將動(dòng)態(tài)php腳本分析統(tǒng)統(tǒng)扔給fast-cgi,這樣一來(lái)能將動(dòng)態(tài)腳本分析過(guò)程從nginx進(jìn)程中解放出來(lái)從而增強(qiáng)nginx的并發(fā)能力,二來(lái)當(dāng)php掛了不至于讓nginx一起掛了
介紹完fast-cgi的重要性,只是希望告訴大家雖然現(xiàn)在php-fpm占用了不少的內(nèi)存空間,但可不能將其打入冷宮,隨隨便便把它們kill或者將php-fpm服務(wù)停掉了(這樣你的網(wǎng)站將無(wú)法訪問(wèn)),下面先介紹一下php-fpm配置文件一些重要參數(shù)的含義,然后再針對(duì)性得做些優(yōu)化措施
由于我是rpm安裝的php-fpm,所以得先找找相關(guān)配置文件
# rpm -qc php-fpm /etc/logrotate.d/php-fpm /etc/php-fpm.conf /etc/php-fpm.d/www.conf /etc/sysconfig/php-fpm根據(jù)上方ps的提示,我們這里應(yīng)當(dāng)重點(diǎn)優(yōu)化php-fpm與www相關(guān)的參數(shù)
# cat /etc/php-fpm.d/www.conf | grep -v "^;" [www] listen = 127.0.0.1:9000 listen.allowed_clients = 127.0.0.1 user = apache group = apache pm = dynamic # pm模式 pm.max_children = 20 # 大可創(chuàng)建的子進(jìn)程的數(shù)量 pm.start_servers = 10 # 隨著php-fpm-master一起啟動(dòng)時(shí)創(chuàng)建的子進(jìn)程數(shù)目 pm.min_spare_servers = 5 # 服務(wù)器空閑時(shí)最小php-fpm進(jìn)程數(shù)量 pm.max_spare_servers = 20 # 服務(wù)器空閑時(shí)大php-fpm進(jìn)程數(shù)量 slowlog = /var/log/php-fpm/www-slow.log # 慢查詢?nèi)罩敬娣怕窂?php_admin_value[error_log] = /var/log/php-fpm/www-error.log php_admin_flag[log_errors] = on php_value[session.save_handler] = files php_value[session.save_path] = /var/lib/php/sessionpm的三種模式:
static 表示我們創(chuàng)建固定數(shù)量的php-fpm子進(jìn)程,所以只有 pm.max_children=20 參數(shù)生效。啟動(dòng)php-fpm時(shí)會(huì)一次性全部啟動(dòng)21(1個(gè)主+20個(gè)子)個(gè)進(jìn)程
dynamic 表示啟動(dòng)進(jìn)程是動(dòng)態(tài)分配的,子進(jìn)程的數(shù)量隨著請(qǐng)求量的變化以及上述一些參數(shù)限制動(dòng)態(tài)變化著
ondemand 該模式下按需分配、銷(xiāo)毀子進(jìn)程,子進(jìn)程捆綁了空閑計(jì)時(shí)器 pm.process_idle_timeout 一旦空閑時(shí)間計(jì)時(shí)器超時(shí)就將子進(jìn)程kill
所以,現(xiàn)在結(jié)合php-fpm的默認(rèn)配置就能解釋:上面用ps輸出發(fā)現(xiàn)系統(tǒng)跑著20個(gè)php-fpm子進(jìn)程的原因了
我這個(gè)小小站,根據(jù) pm.start_servers=10 剛啟動(dòng)php-fpm時(shí)會(huì)產(chǎn)生1個(gè)主進(jìn)程以及10個(gè)子進(jìn)程,當(dāng)這10個(gè)子進(jìn)程對(duì)用戶的大量動(dòng)態(tài)請(qǐng)求忙不過(guò)來(lái)時(shí),將不斷啟動(dòng)新的php-fpm子進(jìn)程以滿足需要,但根據(jù) pm.max_children=20 系統(tǒng)最多只會(huì)產(chǎn)生20個(gè)子進(jìn)程,而由于 pm.max_spare_servers=20 假設(shè)某時(shí)間段內(nèi),網(wǎng)站一直沒(méi)人訪問(wèn),但卻仍需維護(hù)著20個(gè)子進(jìn)程,對(duì)于像我這種小小站而言,子進(jìn)程的空閑數(shù)量過(guò)多了,所以這也是一個(gè)優(yōu)化點(diǎn),嘮叨這么多怕大家反而暈頭轉(zhuǎn)向的,不妨瞅瞅我隨手畫(huà)的圖加深理解
大家有了這些知識(shí)做鋪墊,想必php-fpm的優(yōu)化技巧不用我說(shuō)也能猜到一二了吧(如果看官依然懵逼那只能說(shuō)“看來(lái)我這水平還不夠”)
優(yōu)化方案1:pm模式使用dynamic
配置要點(diǎn)
# vim /etc/php-fpm.d/www.conf pm = dynamic pm.max_children = 8 pm.start_servers = 3 pm.min_spare_servers = 3 pm.max_spare_servers = 5重啟 php-fpm 并查看內(nèi)存占用情況
# service php-fpm restart 停止 php-fpm: [確定] 正在啟動(dòng) php-fpm: [確定] # free -m total used free shared buffers cached Mem: 996 410 585 0 90 111 -/+ buffers/cache: 209 787 Swap: 0 0 0現(xiàn)在內(nèi)存使用量的確舒服多了,順便看看初始時(shí)啟用的子進(jìn)程數(shù)目
# ps aux | grep php-fpm | wc -l 55-2=3符合我們上方 pm.start_servers=3 的修改
此時(shí)nginx尚未配置頁(yè)面緩存,所以可以不斷刷新站點(diǎn)來(lái)測(cè)試(讓僅有的3個(gè)fpm進(jìn)程忙不過(guò)來(lái))看看內(nèi)存占用情況,下面貼出測(cè)試后的現(xiàn)象
# free -m total used free shared buffers cached Mem: 996 517 478 0 90 112 -/+ buffers/cache: 314 681 Swap: 0 0 0# ps aux | grep php-fpm | wc -l 7系統(tǒng)當(dāng)前運(yùn)行的php-fpm子進(jìn)程個(gè)數(shù)也符合我們?cè)O(shè)置的 pm.max_spare_servers=5 (大空閑進(jìn)程數(shù))
優(yōu)化方案2:pm模式使用 ondemand
配置要點(diǎn)
# vim /etc/php-fpm.d/www.conf pm = ondemand網(wǎng)站在某刻有大量請(qǐng)求涌入時(shí),內(nèi)存占用情況
# free -m total used free shared buffers cached Mem: 996 765 231 0 90 112 -/+ buffers/cache: 561 435 Swap: 0 0 0網(wǎng)站平穩(wěn)時(shí)(沒(méi)人訪問(wèn))系統(tǒng)只跑了個(gè) php-fpm master 進(jìn)程(因?yàn)樽舆M(jìn)程由于閑置時(shí)間過(guò)長(zhǎng)而被kill掉了)所以此時(shí)內(nèi)存占用也就大大降低啦
# ps aux | grep php-fpm root 29549 0.0 0.6 317072 6148 ? Ss 10:16 0:00 php-fpm: master process (/etc/php-fpm.conf) root 30099 0.0 0.0 103272 884 pts/0 S+ 10:28 0:00 grep php-fpm # free -m total used free shared buffers cached Mem: 996 414 582 0 91 115 -/+ buffers/cache: 207 789 Swap: 0 0 0看到這里,想必各位看官也能自己總結(jié)出php-fpm各模式下的優(yōu)缺點(diǎn)以及php-fpm的優(yōu)化技巧了吧
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無(wú)理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。