Ber*_*lin 2 linux php-fpm php7
我尝试了以下命令来检查单个 PHP-FPM 进程的平均内存使用情况
ps --no-headers -o "rss,cmd" -C php-fpm | awk '{ sum+=$1 } END { printf ("%d%s\n", sum/NR/1024,"M") }'
Run Code Online (Sandbox Code Playgroud)
我有一个错误 awk: cmd. line:1: fatal: division by zero attempted
而这个命令
total=0; for i in `ps -C php-fpm -o rss=`; do total=$(($total+$i)); done; echo "Memory usage: $total kb";
Memory usage: 0 kb
ps -ef | grep php
root 9435 1 0 11:42 ? 00:00:00 php-fpm: master process (/etc/php/7.0/fpm/php-fpm.conf)
somename+ 9438 9435 0 11:42 ? 00:00:00 php-fpm: pool somename-1
somename+ 9439 9435 0 11:42 ? 00:00:01 php-fpm: pool somename-1
...
...
Run Code Online (Sandbox Code Playgroud)
对于匹配的ps
选项-C
,您需要确保您正在寻找正确的字符串 - 不是默认显示的扩展命令名称 eg -ef
,而是该c
选项与 eg 组合显示的内容ax
。
相比:
% ps -ef | grep '[f]'pm
www-data 3014 3714 2 19:09 ? 00:01:16 php-fpm: pool www
root 3714 1 0 Srp03 ? 00:00:32 php-fpm: master process (/etc/php/7.0/fpm/php-fpm.conf)
www-data 10644 3714 2 18:14 ? 00:02:35 php-fpm: pool www
www-data 18448 3714 2 19:42 ? 00:00:28 php-fpm: pool www
% ps axc | grep '[f]'pm
3014 ? S 1:17 php-fpm7.0
3714 ? Ss 0:32 php-fpm7.0
10644 ? S 2:35 php-fpm7.0
18448 ? S 0:28 php-fpm7.0
Run Code Online (Sandbox Code Playgroud)
在这个例子中,匹配的字符串-C
是php-fpm7.0
:
% ps -C php-fpm7.0 -o rss=
32516
65952
61468
61012
Run Code Online (Sandbox Code Playgroud)
小智 5
我不知道在哪里找到它,但它有效!
ps -eo size,pid,user,command --sort -size | awk '{ hr=$1/1024 ; printf("%13.2f Mb ",hr) } { for ( x=4 ; x<=NF ; x++ ) { printf("%s ",$x) } print "" }' | grep php-fpm
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
9126 次 |
最近记录: |