JMeter概述
与wrk 相比,JMeter 是一款更专业的性能测试工具,提供更多管理选项,提供GUI 。笔者在开发完成API 工作后会做一些性能测试。整体感受就是功能比较强大,GUI 方便配置参数,适合专业测试人员使用。
问题
后端性能测试过程中,我们希望模拟一个完整的请求过程,即:
- 模拟用户登录成功
- 模拟用户频繁执行某个操作,达到API性能测试目的。
那么问题来了。步骤2 中如何得到步骤1 的session/token 信息呢?我们需要配置JMeter 以便获取到相关信息。下面是通过正则表达式提取JSESSIONID 的步骤。
- 确认项目中各个接口的请求/响应信息
- 登录接口需要添加
HTTP信息头管理器 ,请求参数全部需要指定,否则响应信息中可能会不存在Set-Cookie 信息。另外笔者初步理解Set-Cookie 可以放在响应体或者响应头中,但是本项目放在在响应头中。
- 在登录接口中添加
正则表达式提取器 用于提取JSESSIONID - 在测试接口中,添加
HTTP Cookie管理器 ,获取上一步中的JSESSIONID
总结
- 读者可能会有疑问,为什么性能测试需要给
API 提供session 信息? 服务端使用session 标记客户端会话请求,将每一个restful 的无状态请求变成有状态请求。Tomcat 中存在一个全局静态变量Map<String, Object> sessions ,存放session 。用户第一次请求后会将此sessionid 信息放入sessions ,后续请求会从sessions 中查找此session 是否存在,存在就使用;不存在就创建一个新的sessionid 加入sessions 。 - 性能测试中是否可以不传递
session 信息? 参考上文,如果不传递session ,性能测试会产生很多sessionid ,继而导致JVM 堆空间被塞满引发OOM ,详细信息可以参看笔者这篇文章 - 注意:性能测试需要处理关于
session 的问题,实际线上环境不会出现这个问题。因为用户登陆成功后去在界面操作,都会正常携带session 信息的。笔者当前只解决了通过正则获取JSESSION 的信息,下一步是基于JMeter走通一个完整的性能测试流程。
引用
- https://www.cnblogs.com/liulinghua90/p/9257548.html [JMeter关联Cookie信息]
|