天天看点

linux中使用jmeter压力测试及性能调优

作者:散文随风想

1.上传jmx格式的脚本,

修改权限 chmod 777 XX.jmx

2.执行脚本

jmeter -n -t denglu200.jmx -l denglu200.jtl                

-n代表nogui 格式

-t 代表执行的脚本

-l代表日志文件

3. 编辑JMX测试脚本

在linux 里用 vim 编辑 XX.jmx 脚本 ,可以直接修改线程数,循环次数。

线程启动时间,测试链接,参数化的文件要上传到服务器上,然后修改路径。

4. 问题

a.问题一:

测试中遇到问题一,报oom。

在执行 jmeter -n -t shouye.jmx -l shouye.jtl,在每台测试机并发3w线程时,测试机器报oom 内存溢出,导致测试执行不下去,

解决方法:

  1. 查看测试机内存大小,
  2. 本测试机内存16g,
  3. 更改执行jmeter的时候java虚拟机的内存
    1. 进入jmeter 和jmeter.sh 两个文件
      1. 注释掉 HEAP="-Xms512m -Xmx512m" 和java $ARGS $JVM_ARGS $JMETER_OPTS -jar "$PRGDIR/ApacheJMeter.jar" "$@"
      2. 在最后一行添加这个java $JVM_ARGS -Xms2G -Xmx8G -XX:MaxPermSize=512m -Dapple.laf.useScreenMenuBar=true -jar `dirname $0`/ApacheJMeter.jar "$@"两个就可以修改jmeter 运行的jvm内存大小,这样运行jmeter时,就是分配的内存最大变为8G,解决了 测试机报内存溢出的问题。

b. 问题二

  1. 测试中遇到问题二,连接数限制报socketexception
  2. 继续执行 jmeter -n -t shouye.jmx -l shouye.jtl,在每台测试机并发3w线程时,测试机不报内存溢出,但是响应错误率很高

问题分析:

查看日志得出,问题原因是 SocketException ,此问题是由于 测试机安装后默认 最大连接数比较小。

用查看连接数 netstat -an|wc -l 看了是1024,果然很小。

查看连接数范围 cat /proc/sys/net/ipv4/ip_local_port_range。

解决:

  1. 修改链接数,
    1. 调节至最大端口范围echo net.ipv4.ip_local_port_range = 1024 65000 >> /etc/sysctl.conf
    2. 让其生效 sysctl -p
  2. 设置最大可大开文件数
    1. ulimit -n 102400
    2. 查看最大开文件数 ulimit -n。

至此测试机可以正常运行,

c.问题三

生成html报告,在3.0以上版本jmeter可以

进入jmeter bin 目录中bin/jmeter.property 修改配置后显示

jmeter.save.saveservice.output_format=csv
jmeter.save.saveservice.default_delimiter=,           
保存,每次在压测跑完后才可生成报告,如果强制kill掉进程的话,生成报告会遇到报错Error while processing samples:Mismatch between expected number of columns:14 and columns in CSV file:2, check your jmeter.save.saveservice.* configuration

解决方案

进入 XXX.jtl文件中,用G 进入到文件的最后一行,因为格式不全,导致生成报错,删掉最后一行不完整的信息,再保存,然后再执行jmeter -g shouye.jtl -e -o /usr/local/test/upload/apache-jmeter-3.0/testplan/shouyeresultReport,就可以生成html格式的报告,下载到本地就可以打开。

5.测试执行时用到的linux命令

a.复制一个文件到另一台测试机上 ,

scp tijiaodingdan.jmx [email protected]:/usr/local/test/upload/apache-jmeter-3.0/testplan           

b.查看日志命令

tail -f jmeter.log           

c.查看生成jtl 文件具体日志里面有报错信息 命令

tail -f  shouye.jtl            

d.查看jmeter 进程号

ps -ef |grep jmeter 

# 用jps查找的只是子进程号
# kill掉进程命令 kill -9 进程号  先kill父进程号 再kill子进程号           

继续阅读