同伴们,
我正在玩一个RHEL 5.4盒子里的单线程,并且完美的工作:
TOTAL_RAM=`free | grep Mem: | awk '{ print $2 }'`; \ ps axo rss,comm,pid | awk -v total_ram=$TOTAL_RAM \ '{ proc_list[$2] += $1; } END { for (proc in proc_list) \ { proc_pct = (proc_list[proc]/total_ram)*100; printf("%d\t%s\t%0.2f%\n", proc_list[proc],proc,proc_pct); }}' \ | sort -n | tail -n 10
在RHEL框中输出如下所示的内容:
3736 logmon 0.01% 4156 EvMgrC 0.01% 4692 hald 0.01% 5020 ntpd 0.02% 6252 sshd 0.02% 7784 cvd 0.02% 9224 snmpd 0.03% 13068 dsm_sa_datamgr3 0.04% 23320 dsm_om_connsvc3 0.07% 4249864 mysqld 12.90%
但是在我的Ubuntu 9.04切片,我得到这个:
awk: run time error: not enough arguments passed to printf("%d %s %0.2f% ") FILENAME="-" FNR=104 NR=104 33248 console-kit-dae 3.17
我认为这应该是bashing borking的东西,但我真的没有做任何应该是特定的bash。 RHEL框正在运行:
# yum info bash | grep -e Version -e Release Version : 3.2 Release : 24.el5
和Ubuntu的盒子:
# apt-cache show bash | grep -e Version Version: 3.2-5ubuntu1
我还没有深入到这个超级,我想我会和我的同事们见面,看看你以前是否碰到过这个。
/弓
这个命令在每个系统上显示的是什么:
echo $BASH_VERSION
而且由于错误消息是由awk产生的,这显示了什么:
awk --version | head -n 1
除了克里斯提出的逃避printf最后一个% 的build议(可以用一个反斜杠或者加倍百分号来实现)之外,可能不会在下一行之前在行末加一个连续的反斜杠printf 。
我只能说,它在我的Ubuntu 9.10上工作得很好。 但是你的第4个符号对我来说看起来有点奇怪,就好像它依赖于一些不完美的行为。 它不应该逃脱吗?
TOTAL_RAM=`free | grep Mem: | awk '{ print $2 }'`; \ ps axo rss,comm,pid | awk -v total_ram=$TOTAL_RAM \ '{ proc_list[$2] += $1; } END { for (proc in proc_list) \ { proc_pct = (proc_list[proc]/total_ram)*100; printf("%d\t%s\t%0.2f%%\n", proc_list[proc],proc,proc_pct); }}' \ | sort -n | tail -n 10
如果你只是在寻找内存的百分比,你可以这样做:
top -b -n1
你会得到一些额外的信息,但更容易awk出来。 Top允许一个批处理模式,使得所有的诅咒垃圾不会被传送到其他应用程序。