我正在针对Java进程运行一些JMeter测试,以确定Web应用程序的负载响应程度(500+用户).JMeter将为每个Web请求提供响应时间,并且我已经编写了一个脚本来每隔X秒ping Tomcat Manager,这将获得JVM堆的当前大小.
我想在服务器上收集Tomcat使用的CPU百分比的统计信息.我尝试在shell脚本中使用ps
这样的方法:
PS_RESULTS=`ps -o pcpu,pmem,nlwp -p $PID`
...每隔X秒运行一次命令并将结果追加到文本文件中.(对于任何想知道的人来说,pmem
=%mem使用率和nlwp
线程数)
但是我发现这给出了"CPU利用率百分比"的不同定义 - 根据ps的联机帮助页,pcpu
定义为:
cpu利用"##.#"格式的进程.它是使用的CPU时间除以进程运行的时间(cputime/realtime ratio),以百分比表示.
换句话说,pcpu
给出了进程生命周期内进程的%CPU利用率.
因为我想每X秒采样一次,所以我只想在当前时间收集进程的CPU利用率 - 类似于top
给我的(自上次更新以来进程的CPU利用率).
如何从shell脚本中收集它?
使用top -b
(和其他开关,如果你想要不同的输出).它只会转储到stdout而不是跳进curses窗口.
我发现在监视服务器时执行测试的最有用的工具是dstat,例如JMeter .它不仅为您提供服务器的一系列统计数据,还输出到csv以便于导入电子表格,并允许您使用Python编写的模块扩展该工具.