誰貪佔了我的系統資源 php-fpm
編者按:本文的分析思路值得參考。
測試人員向我們反映:在Facebook平臺的遊戲比其它平臺的遊戲明顯更慢。我詢問,是不是因為翻牆網路原因。他們說:不是,其它遊戲也比較流暢。
使用httpwatch檢視了http請求,發現api.php請求花了6秒,且大部分時間是紅色(httpwatch紅色表示伺服器運算時間)。平常2秒,現在6秒,伺服器處理時間在不同的伺服器相差這麼多。
直覺告訴:伺服器資源。
伺服器概況
- 作業系統:CentOS5.3-64-2.6.18-164.el5
- 應用服務Nginx0.6、PHP-Fpm、MySQL5.1、PHP5.2、Memcached
- Memcached僅cached遊戲系統設定與模板引數據
故障檢測
1.別的先不管,先top看一下cpu、ram、swap哪個比較緊張。
由上圖分析,可以看出共有602個程式,其中有601個程式休眠了。這好像有點不對勁,核心程式也就80個左右,加上memcached, nginx, mysqld,也不會超出90個。除了這些,剩下的只有php-fpm管理的php-cgi,難道是…?
CPU顯示,CPU壓力並不大,可以說沒有壓力。我們再看記憶體使用概要,發現4G的記憶體,消耗得所剩餘無幾(free+buffers), 95%以上的記憶體都已分配。互動空間使用情況,我們暫時不去關心。指令top還列出了佔用資源最多的程式,執行時間最久(Time+)的mysqld(約2小時)佔用資源並不是最多。另外,再看php-cgi,單個php-cgi佔用的記憶體也不算多。所以,可以大膽地猜想:伺服器記憶體資源比較緊張,並沒有被某個程式佔用大量記憶體,有可能被某些掛起的程式佔著記憶體沒有釋放。通過free進一步監控記憶體使用情況,驗證我們的想法。
2.指令free,瞭解RAM資源使用情況。當然,你也可以檢視檔案/proc/meminfo
我們先來看Mem統計資訊,total表示實體記憶體總量,約4G。used,表示已分配記憶體,分配了並不表示使用了,包括(buffer&cached)。free指未分配的記憶體,buffers與cached表示分配了但還沒有被使用的記憶體。第二行(buffers/cache)的,used表示真正被使用了記憶體,由第一行的(used-buffer-cached)得到,free則表示還沒有被使用的記憶體,由第一行的(free+buffer+cached)得到。Swap行則表示記憶體交換使用情況,少量的(不頻繁地)swpd,是不會影響伺服器效能的,因為系統需要將V型別的記憶體頁面交換出去或者調整了buffer與cached的大小。但是頻繁地swpd,則有可能意味著伺服器實體記憶體不足,小於指定的swap額定值,需要換出記憶體頁。
檢視free結果的時候,我們主要檢視第二行。一眼就能看出4G的記憶體,其中有3898M記憶體被用了,還有49M記憶體沒有,都快用完了。這也證實了我們第一步的猜想,記憶體被用完。這裡,我們進一步猜想,記憶體空間嚴重不足的情況下,程式會被blocked,系統會不斷地將不用的資料換出so,將要用的資料讀入si。我們能通過vmstat進一步驗證,我們的這個猜想。
3.指令vmstat監控記憶體使用情況
作為對記憶體監控,我們比較關心swpd、free、si、so。一般系統不繁忙的狀態下,我們看到swpd,so的值不會持續很高,經常為0。這裡,我們看到swpd值為1.5G,以及free值很小,再一次表明實體記憶體不足。其中si報告了每秒從swap區移入到實體記憶體的記憶體總量,so報告了每秒從實體記憶體移出到swap區的記憶體總量。當然,si有時較大,並不要過份的焦慮,經常碰到一個程式需要較大記憶體來讀寫媒體檔案時,si值就會變大。反倒是so,它通常是一個記憶體緊缺的一個訊號,如果長時間這個值一直保持較大的話,則很有可能記憶體不夠,小額波動,可以不用理會。接下來,可以通過ps找出消耗記憶體的元凶。
4.指令ps找出消耗記憶體的元凶
指令ps比較常用,也比較簡單。上面報告結果,我們一眼就可以命中php-cgi這個程式。雖然單個php-cgi佔用記憶體並不算太大,但是503個php-cgi程式,就有點恐怖了。幾乎佔盡了全部記憶體(503*0.3%)。我們可以猜想,php-cgi由php-fpm管理,是不是可以php-fpm的某個引數配置不當,導致開啟過多的php-cgi程式。
5. 設定php-fpm程式數量管理
通過重新將php-conf.conf的max_children值設定為150,系統記憶體又恢復到正常使用情況。free、si、so、b均表示記憶體系統資源正常,沒有壓力。
php-cgi程式釋放的記憶體並不會被系統立即回收,一個php-cgi大概佔用20MB記憶體(取決於你載入的php extensions)。所以,有必要限制你啟動的php-cgi程式數量。那麼,這個數量多少合適呢,你可以在伺服器高峰期通過top統計出php-cgi數量。也可以像php-fpm建議的那樣,通過netstat -np | grep 127.0.0.1:9000來收集資料,通過設定max_children使等待的數量儘量小
6.一個php-cgi佔用多少記憶體
一個php-cgi程式,大概佔用多少記憶體呢,大概是20MB(具體的要看你的php載入了多少模組)。可以通過pmap指令檢視哪些地方佔用了記憶體。所以,儘量不要載入不必要的php擴充套件模組,可以減少不必要的記憶體浪費。
相關文章
- ES資料沒了?誰動了我的資料?
- 誰動了我的 Redis ?Redis
- 誰動了我的MySQL?MySql
- 誰動了我的 DOM?
- 誰霸佔了你的手機?
- 超酷的開源任務協作系統,我粉了
- 誰動了我的程式碼!?
- 分享5款佔用系統資源少的軟體
- 誰動了我的資料?如何防止資料偷偷溜走?
- Jtti:為什麼Linux系統的伺服器佔用資源更少?JttiLinux伺服器
- CPU飆升?教你1分鐘抓取佔用系統資源的程式
- 推薦5款不佔系統資源的小工具軟體
- 我把Linux系統上面誤刪的資料找回來了Linux
- win10系統下taskhost.exe佔用資源如何禁用Win10
- 誰動了我的DevOps:DevOps風險測繪dev
- 在Docker中,如何控制容器佔用系統資源(CPU,記憶體)的份額?Docker記憶體
- 誒,我的動態資料來源怎麼失效了
- 《資料安全法》正式實施 動了誰的乳酪?紅了誰的櫻桃?
- windows10系統下wsappx程式佔用資源過多如何解決WindowsAPP
- 共享資源庫系統
- 我用 go-zero 一週實現了一箇中臺系統,已開源!Go
- 檢視PHP-FPM的記憶體佔用、程序個數等資訊PHP記憶體
- 我已經受夠了“系統異常”!
- 輕量級Nacos來了!佔用資源極低,效能炸裂!
- 《資料安全法》動了誰的“乳酪”
- 誰動了我的 Linux?原來 history 可以這麼強大!Linux
- 人力資源管理系統1.0
- win10系統中csrss.exe程式佔用GPU資源高如何解決Win10GPU
- 臥槽,sql注入竟然把我們的系統搞掛了SQL
- mac系統,php-fpm加入開機啟動項MacPHP
- 資源記憶體佔用記憶體
- 5W1H聊開源之Who——誰“發明”了開源?
- Android系統“資源排程框架”Android框架
- 人力資源系統選型指南
- 淺談遊戲的經濟資源系統遊戲
- Linux 下檢視系統資源的更好方式Linux
- 人力資源管理系統和oa的區別?
- 誰喚醒了我的電腦?
- [資源]基於 Pytorch 的 TorchGAN開源了!PyTorch