前言
在做性能测试时,想要在一定CPU利用率的条件下运行测试系统,就需要保持CPU利用率在一定得范围内。想了好多方法,开始是通过jmeter调用接口的方法实现,但是不能一致保持CPU在一定范围内;然后又利用jmeter录制了脚本,可想而知,其实原理一样,还是以失败而告终。苦恼苦恼,在别人的提点下,shell脚本可以实现,于是开始了探索之路。。。。。。结果是,成功的实现了。启发就是,在一种思路不行的情况下,学会换种思路思考,获取有意想不到的收获。
实现
#! /bin/bash
# filename test.sh
endless_loop()
{
echo -ne "i=0;
while true
do
i=i+100;
i=100
done" | /bin/bash &
}
if [ $# != 1 ] ; then
echo "USAGE: $0 "
exit 1;
fi
for i in `seq $1`
do
endless_loop
pid_array[$i]=$! ;
done
for i in "${pid_array[@]}"; do
echo 'kill ' $i ';';
done
考虑到服务器大多都是多核CPU,我们可以自由的选择消耗多少颗CPU的资源;使用方法就是在命令的后面传递参数,即参数8表示消耗8颗CPU的资源;而运行后,会有一堆 kill 命令,运行这些命令即可kill掉死循环进程。
运行
运行命令:
./test.sh m
如果服务器是8核,即./test 8
输出:
kill 20926 ;
kill 20928 ;
kill 20930 ;
kill 20932 ;
kill 20934 ;
kill 20936 ;
kill 20938 ;
kill 20940 ;
实际的运行结果:
利用top命令可以清楚的查看cpu的运行情况
保持CPU在一定范围内已经实现了,实属不容易