秒杀项目学习第四章

主要内容

  1. JMeter入门
  2. 自定义变量模拟多个用户
  3. JMeter命令行使用
  4. Redis压测工具redis-benchmark
  5. Spring Boot打war包

一、JMeter入门

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命令行使用

  1. 在Windows上录好jmx
  2. 命令行:sh jmeter.sh -n -t XXX.jmx -l result.jtl
  3. 把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包

  1. 添加spring-boot-starter-tomat的provided依赖
  2. 添加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
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值