主要内容
- JMeter入门
- 自定义变量模拟多个用户
- JMeter命令行使用
- Redis压测工具redis-benchmark
- Spring Boot打war包
一、JMeter入门
压测商品列表页面
主要衡量并发在XXX时的QPS是多少
1.打开jmeter.bat
2.测试计划中添加线程组
设置线程组
3.在线程组中添加HTTP请求默认值
设置参数
3.在线程组中添加HTTP请求
设置参数
4.在线程组中添加监听器
如聚合报告
压测过程一个bug的解决
UserArgumentResolver.getCookieValue中获取cookies时可能报空指针异常,加一个判断
5.结果查看
6.性能瓶颈分析
使用top命令监控系统硬件使用,发现mysql是阻碍性能的关键
带参数路径压测示例
1.自定义一个路径,并在controller方法参数中带上MiaoshaUser,这样路径请求时需要带token参数
2.使用JMeter压测
3.看结果
为何这个QPS比上一个方法高?
因为获取用户的时候用到了Redis!
二、自定义变量模拟多个用户
1.添加CSV Data Set Config
2.userInfo文件内容如下
3.修改参数
4.压测结果
三、 JMeter命令行使用
- 在Windows上录好jmx
- 命令行:sh jmeter.sh -n -t XXX.jmx -l result.jtl
- 把result.jtl导入到jmeter
先把项目打个jar包传服务器上,jmeter也传上去
压测商品列表页面
1.在Windows上录好jmx
上传到服务器
2.执行
jmeter.sh -n -t XXX.jmx -l result.jtl
3.把result.jtl导入到jmeter
压测秒杀方法
1.生成用户token
public class UserUtil {
private static void createUser(int count) throws Exception{
List<MiaoshaUser> users = new ArrayList<MiaoshaUser>(count);
//生成用户
for(int i=0;i<count;i++) {
MiaoshaUser user = new MiaoshaUser();
user.setId(13000000000L+i);
user.setLoginCount(1);
user.setNickname("user"+i);
user.setRegisterDate(new Date());
user.setSalt("1a2b3c");
user.setPassword(MD5Util.inputPassToDbPass("123456", user.getSalt()));
users.add(user);
}
System.out.println("create user");
// //插入数据库
// Connection conn = DBUtil.getConn();
// String sql = "insert into miaosha_user(login_count, nickname, register_date, salt, password, id)values(?,?,?,?,?,?)";
// PreparedStatement pstmt = conn.prepareStatement(sql);
// for(int i=0;i<users.size();i++) {
// MiaoshaUser user = users.get(i);
// pstmt.setInt(1, user.getLoginCount());
// pstmt.setString(2, user.getNickname());
// pstmt.setTimestamp(3, new Timestamp(user.getRegisterDate().getTime()));
// pstmt.setString(4, user.getSalt());
// pstmt.setString(5, user.getPassword());
// pstmt.setLong(6, user.getId());
// pstmt.addBatch();
// }
// pstmt.executeBatch();
// pstmt.close();
// conn.close();
// System.out.println("insert to db");
//登录,生成token
String urlString = "http://localhost:8080/login/do_login";
File file = new File("D:/tokens.txt");
if(file.exists()) {
file.delete();
}
RandomAccessFile raf = new RandomAccessFile(file, "rw");
file.createNewFile();
raf.seek(0);
for(int i=0;i<users.size();i++) {
MiaoshaUser user = users.get(i);
URL url = new URL(urlString);
HttpURLConnection co = (HttpURLConnection)url.openConnection();
co.setRequestMethod("POST");
co.setDoOutput(true);
OutputStream out = co.getOutputStream();
String params = "mobile="+user.getId()+"&password="+MD5Util.inputPassToFormPass("123456");
out.write(params.getBytes());
out.flush();
InputStream inputStream = co.getInputStream();
ByteArrayOutputStream bout = new ByteArrayOutputStream();
byte buff[] = new byte[1024];
int len = 0;
while((len = inputStream.read(buff)) >= 0) {
bout.write(buff, 0 ,len);
}
inputStream.close();
bout.close();
String response = new String(bout.toByteArray());
JSONObject jo = JSON.parseObject(response);
String token = jo.getString("data");
System.out.println("create token : " + user.getId());
String row = user.getId()+","+token;
raf.seek(raf.length());
raf.write(row.getBytes());
raf.write("\r\n".getBytes());
System.out.println("write to file : " + user.getId());
}
raf.close();
System.out.println("over");
}
public static void main(String[] args)throws Exception {
createUser(5000);
}
}
2.录制jmx
3.上传服务器执行即可得到结果
注意上传后修改jmx文件中token.txt的路径
出现的问题
查看数据库发现商品库存变为负数—卖超了
四. Redis压测工具redis-benchmark
命令一:
100个并发连接,100000个请求
redis-benchmark -h 127.0.0.1 -p 6379 -c 100 -n 100000
命令二:
存取大小为100的数据包
redis-benchmark -h 127.0.0.1 -p 6379 -q -d 100
命令三:
只测试某些操作性能
redis-benchmark -t set,lpush -n 100000 -q
命令四:
只测试某些数值存取的性能
redis-benchmark -n 100000 -q script load "redis.call('set','foo','bar')"
五、Spring Boot打war包
- 添加spring-boot-starter-tomat的provided依赖
- 添加maven-war-plugin插件
添加依赖
provided表明编译时依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>
添加plugin
修改packaging
主类继承SpringBootServletInitializer
maven执行package命令
找个tomcat测试一波
放到webapps目录下边后启动tomcat即可
访问路径注意加context路径
http://localhost:8080/miaosha_study/login/to_login