新聞中心
本文操作環(huán)境:linux5.9.8系統(tǒng)、php5.5版、DELL G3電腦

網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)!專注于網(wǎng)頁設(shè)計、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團企業(yè)網(wǎng)站建設(shè)等服務(wù)項目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了鹽津免費建站歡迎大家使用!
php 進程太多怎么辦?
linux服務(wù)器php-fpm進程數(shù)過多導(dǎo)致內(nèi)存占滿處理:
早上到單位 發(fā)現(xiàn)服務(wù)器 mysql 服務(wù)器停了 然后起來了
查詢?nèi)罩?顯示 內(nèi)存滿了 把mysql服務(wù)給殺了 linux 服務(wù)器如果 內(nèi)存滿了 會自動清理進程 防止服務(wù)器掛掉 選擇的話 誰占的的內(nèi)存大 就先殺誰 我的服務(wù)器里面 mysql服務(wù)占的內(nèi)存是最大的 所以就把mysql就給殺了
然后 重啟mysql 查詢內(nèi)存
在這說一下 怎么看linux的內(nèi)存
舉個例子
如下顯示free是顯示的當前內(nèi)存的使用,-m的意思是M字節(jié)來顯示內(nèi)容.我們來一起看看.
$ free -m total used free shared buffers cached Mem: 1002M 769M 232M 0M 62M 421M -/+ buffers/cache: 286M 715M Swap: 1153M 0M 1153M --------------------------- 真實內(nèi)存占用 = used-buffers-cached = 286M -----------------
第一部分Mem行:
total 內(nèi)存總數(shù): 1002M used 已經(jīng)使用的內(nèi)存數(shù): 769M free 空閑的內(nèi)存數(shù): 232M shared 當前已經(jīng)廢棄不用,總是0 buffers Buffer 緩存內(nèi)存數(shù): 62M cached Page 緩存內(nèi)存數(shù):421M
關(guān)系:total(1002M) = used(769M) + free(232M)
第二部分(-/+ buffers/cache):
(-buffers/cache) used內(nèi)存數(shù):286M (指的第一部分Mem行中的used - buffers - cached) (+buffers/cache) free內(nèi)存數(shù): 715M (指的第一部分Mem行中的free + buffers + cached)
可見-buffers/cache反映的是被程序?qū)崒嵲谠诔缘舻膬?nèi)存,而+buffers/cache反映的是可以挪用的內(nèi)存總數(shù)。
第三部分是指交換分區(qū), 我想不講大家都明白.
我想大家看了上面,還是很暈.第一部分(Mem)與第二部分(-/+ buffers/cache)的結(jié)果中有關(guān)used和free為什么這么奇怪.
其實我們可以從二個方面來解釋.
對操作系統(tǒng)來講是Mem的參數(shù).buffers/cached 都是屬于被使用,所以它認為free只有232.
對應(yīng)用程序來講是(-/+ buffers/cach).buffers/cached 是等同可用的,因為buffer/cached是為了提高程序執(zhí)行的性能,當程序使用內(nèi)存時,buffer/cached會很快地被使用。
所以,以應(yīng)用來看看,以(-/+ buffers/cache)的free和used為主.所以我們看這個就好了.另外告訴大家一些常識.Linux為了提高磁盤和內(nèi)存存取效率, Linux做了很多精心的設(shè)計, 除了對dentry進行緩存(用于VFS,加速文件路 徑名到inode的轉(zhuǎn)換), 還采取了兩種主要Cache方式:Buffer Cache和Page Cache。前者針對磁盤塊的讀寫,后者針對文件inode的讀寫。這些Cache能有效縮短了 I/O系統(tǒng)調(diào)用(比如read,write,getdents)的時間。
記住內(nèi)存是拿來用的,不是拿來看的.不象windows, 無論你的真實物理內(nèi)存有多少,他都要拿硬盤交換文件來讀.這也就是windows為什么常常提示虛擬空間不足的原因.你們想想,多無聊,在內(nèi)存還有大部分的時候,拿出一部分硬盤空間來充當內(nèi)存.硬盤怎么會快過內(nèi)存.所以我們看linux,只要不用swap的交換空間,就不用擔(dān)心自己的內(nèi)存太少.如果常常 swap用很多,可能你就要考慮加物理內(nèi)存了.這也是linux看內(nèi)存是否夠用的標準哦.
--------------------------------------------------------------------------------------------------------------------------
接來下
發(fā)現(xiàn)服務(wù)器的內(nèi)存就剩1.9G了 再用top命令 查看一下
第一行top分別為:當前時間;系統(tǒng)運行天數(shù);使用者個數(shù);系統(tǒng)負載的平均值,后面的三個值分別為1分鐘前、5分鐘前、15分鐘前進程的平均數(shù),這個數(shù)值超過 CPU 數(shù)目時,說明負載過高
第二行Tasks分別為:進程總數(shù);運行進程數(shù);睡眠進程數(shù);被停止的進程數(shù);被復(fù)原的進程數(shù)
第三行CPU(s)分別為:
us:user 用戶空間占用cpu的百分比
sy:system 內(nèi)核空間占用cpu的百分比
ni:niced 改變過優(yōu)先級的進程占用cpu的百分比
空閑cpu百分比
wa:IO wait IO等待占用cpu的百分比
hi:Hardware IRQ 硬中斷 占用cpu的百分比
si:software 軟中斷 占用cpu的百分比
st:被hypervisor偷去的時間
第四行Mem分別為:總內(nèi)存;已用內(nèi)存;空閑內(nèi)存;緩沖使用中內(nèi)存
第五行(Swap):類似第四行,但反映著交換分區(qū)(Swap)的使用情況。交換分區(qū)(Swap)被頻繁使用,可以看作物理內(nèi)存不足而造成的
top 輸出界面的頂端,也顯示了系統(tǒng)整體的內(nèi)存使用情況,這些數(shù)據(jù)跟 free 類似,我就不再重復(fù)解釋。我們接著看下面的內(nèi)容,跟內(nèi)存相關(guān)的幾列數(shù)據(jù),比如 VIRT、RES、SHR 以及 %MEM 等。
這些數(shù)據(jù),包含了進程最重要的幾個內(nèi)存使用情況,我們挨個來看。
- VIRT 是進程虛擬內(nèi)存的大小,只要是進程申請過的內(nèi)存,即便還沒有真正分配物理內(nèi)存,也會計算在內(nèi)。
- RES 是常駐內(nèi)存的大小,也就是進程實際使用的物理內(nèi)存大小,但不包括 Swap 和共享內(nèi)存。
- SHR 是共享內(nèi)存的大小,比如與其他進程共同使用的共享內(nèi)存、加載的動態(tài)鏈接庫以及程序的代碼段等。
- %MEM 是進程使用物理內(nèi)存占系統(tǒng)總內(nèi)存的百分比。
除了要認識這些基本信息,在查看 top 輸出時,你還要注意兩點。
第一,虛擬內(nèi)存通常并不會全部分配物理內(nèi)存。從上面的輸出,你可以發(fā)現(xiàn)每個進程的虛擬內(nèi)存都比常駐內(nèi)存大得多。
第二,共享內(nèi)存 SHR 并不一定是共享的,比方說,程序的代碼段、非共享的動態(tài)鏈接庫,也都算在 SHR 里。當然,SHR 也包括了進程間真正共享的內(nèi)存。所以在計算多個進程的內(nèi)存使用時,不要把所有進程的 SHR 直接相加得出結(jié)果。
只是這樣看 還是不行 感覺內(nèi)存 不應(yīng)該 占用很多 然后 使用命令 查看 當前系統(tǒng)有多少進程
ps -ef | wc -l
然后使用命令查看占用內(nèi)存最大的500個進程:
ps -aux | sort -k4nr | head -n 500
截取部分 PHP的進程 占到了200個 每個都100多兆
解釋一下含義
USER: 行程擁有者 PID: pid %CPU: 占用的 CPU 使用率 %MEM: 占用的記憶體使用率 VSZ: 占用的虛擬記憶體大小 RSS: 占用的記憶體大小 TTY: 終端的次要裝置號碼 (minor device number of tty) STAT: 該行程的狀態(tài),linux的進程有5種狀態(tài): D 無法中斷的休眠狀態(tài)(通常 IO 的進程); R 正在運行可中在隊列中可過行的; S 處于休眠狀態(tài); T 停止或被追蹤; W 進入內(nèi)存交換 (從內(nèi)核2.6開始無效); X 死掉的進程 (基本很少見); Z 僵尸進程; < 優(yōu)先級高的進程 N 優(yōu)先級較低的進程 L 有些頁被鎖進內(nèi)存; s 進程的領(lǐng)導(dǎo)者(在它之下有子進程); l 多進程的(使用 CLONE_THREAD, 類似 NPTL pthreads); + 位于后臺的進程組; 注: 其它狀態(tài)還包括W(無駐留頁), <(高優(yōu)先級進程), N(低優(yōu)先級進程), L(內(nèi)存鎖頁). START: 行程開始時間 TIME: 執(zhí)行的時間 COMMAND:所執(zhí)行的指令
查詢PHP-fpm 總進程數(shù)
pstree|grep php-fpm
然后 查詢 php-fpm 進程
ps -ef|grep php-fpm
發(fā)現(xiàn)PHP起了四個主進程 這里截取了三個
然后看的PHP 的配置文件
發(fā)現(xiàn)配置的 是 靜態(tài) 配置的50個進程 四個主進程 每個配50個子進程 就200多個進程 進程太多了 平時的話 一般就六七個進程在處理 修改 進程數(shù)量 把50 改成10 這個進程數(shù)量 根據(jù)自己服務(wù)器的內(nèi)存大小 來設(shè)置
查看當前php-fpm進程的內(nèi)存占用情況及啟動時間,命令如下:
ps -e -o 'pid,comm,args,pcpu,rsz,vsz,stime,user,uid'|grep www|sort -nrk5
查看當前php-fpm進程平均占用內(nèi)存情況,一般來說一個php-fpm進程占用的內(nèi)存為30-40MB,命令如下:
ps --no-headers -o "rss,cmd" -C php-fpm | awk '{ sum+=$1 } END { printf ("%d%s\n", sum/NR/1024,"M") }'
然后我重啟了PHP 指定配置文件
步驟
先 查找 然后 殺死
ps aux |grep php
kill 21605 (進程pid)
檢測
啟動
./php-fpm -y /usr/local/php/etc/php-fpm.conf
重啟完 內(nèi)存就降下來了
然后就事查找問題 猜測是內(nèi)存泄露 但是不確定是哪里 對一些感覺有問題的地方 加上了unset()
然后檢測 發(fā)現(xiàn) 內(nèi)存一直都很平穩(wěn)
如果內(nèi)存還是一直增加 可以限制內(nèi)存大小
設(shè)置方法:編輯php-fpm.conf配置文件
php_admin_value[memory_limit] = 128M(我服務(wù)器上的配置文件在/etc/php5/fpm/pool.d/www.conf 這個文件是被包含在php-fpm.conf里的) 后邊的數(shù)字可以隨便更改:32M,64M,128M,256M,512M,這個設(shè)置可根據(jù)你的服務(wù)器內(nèi)存大小和你的需求來寫,修改后要加載一下php-fpm服務(wù)。
這個時候 程序那個步驟出問題了 就說明哪里有內(nèi)存泄露 但是也不是絕對的 這里還要了解一下 PHP的垃圾回收機制
如果你在一個進程里面 應(yīng)該也是 累加的 也不是很好判斷 就要根據(jù)程序 對不用的變量進程銷毀 或者 限制 PHP的進程數(shù)量
注: 普通用戶數(shù)據(jù)1000條 存在數(shù)組里面 大約占2246.2734375kb
普通用戶數(shù)據(jù)2000條 存在數(shù)組里面 大約占4472.8671875kb
標題名稱:php進程太多怎么辦
URL地址:http://m.fisionsoft.com.cn/article/dpdpcgp.html


咨詢
建站咨詢
