目录
jmeter 入门
jmeter 安装
直接解压这个3.3的压缩包,然后双击 jmeter.bat ,可以自己创建个快捷方式。
测试步骤
添加线程组,设置线程数和循环次数
添加一个Http请求
设置http请求
设置http请求,就是设置要访问哪个方法,访问的方法正常来说要走网关,但是这里先不走网关,因为走网关会超时。
添加聚合报告,就是看压测的报告
看每秒的吞吐量
测试数据
1、线程数500 * 循环次数10 总计 5000 次访问
Error 错误率是 0
吞吐量在3500–4200左右
包括目前电脑启动了秒杀项目等多个软件
2、线程数5000 * 循环次数10 总计 50000 次访问
错误率高达40% – 99% 不等
每秒访问的次数是 1700 – 2300 不等,跟上面的5000次访问差很多
记录这个数据,后面进行优化对比
模拟多用户操作
因为t_user 表里面的用户数据超过了半个小时,所以cookie中已经没有了这500个用户的cookie了,所以可以把表阶段,然后重新访问http://localhost:8090/initData这个方法获取500个用户。
测试获取当前登录用户的接口,这个接口
1、创建http请求
访问的方法是获取当前登录用户的数据的方法
设置线程数,自己可以调整
打印出来的都是null,说明没有获取到,因为没有获取到用户的cookie里面的token
2、添加http cookie 管理器
把当前登录用户的cookie的token值写进去
3、并发获取当前登录用户数据的效果
就可以获取到对应的这个登录用户的信息了
4、添加多个用户模拟并发请求
添加工具类
在member-server 服务中,在controller类添加创建500个用户去调用登录方法的代码
5、访问方法
访问这个方法,就可以创建多个500个用户,数据库的user表也有了500个用户的数据
http://localhost:8090/initData
6、jmeter添加 CSV Data Set Config
需要再添加这一个功能
token不能写死,具体的500个用户的token要从txt文件里面去,用 ${} 符号取值
延长redis的超时时间,不然老是会显示redis超时
7、高并发执行访问的效果
用500个用户去访问,一共5000次的访问就轻轻松松不会超时,50000次的话就会有redis的超时问题出现。
现在就有500个用户了,到时候用这500个用户来访问秒杀接口
8、总结流程
第四点 token.txt 不足 500个的问题,我把t_user表截断后重新跑http://localhost:8090/initData就有了
高并发秒杀压测
1、因为t_user 表里面的用户数据超过了半个小时,所以cookie中已经没有了这500个用户的cookie了,所以可以把表阶段,然后重新访问http://localhost:8090/initData这个方法获取500个用户。
就目前的代码,当500个用户同时访问时,都是会超卖或者重复下单的问题。
所以需要优化重复下单和超卖的问题。