jmeter性能测试

本文涉及的产品
性能测试 PTS,5000VUM额度
简介: jmeter是跨平台组件,可在多平台下运行。一般,我在windows下用GUI编写脚本,然后在linux下运行必备安装包apache-jmeter-3.2.zip https://mirrors.

jmeter是跨平台组件,可在多平台下运行。一般,我在windows下用GUI编写脚本,然后在linux下运行

必备安装包

  1. apache-jmeter-3.2.zip https://mirrors.tuna.tsinghua.edu.cn/apache//jmeter/binaries/apache-jmeter-3.2.zip
  2. jdk-8u131-linux-x64.rpm
    http://download.oracle.com/otn-pub/java/jdk/8u131-b11/d54c1d3a095b4ff2b6607d096fa80163/jdk-8u131-linux-x64.rpm?AuthParam=1499493290_8ee142f439f999d97f6bb7e68092b22c

构建测试脚本test.jmx

  1. 添加线程组
    img_6c25261e7948bf0a0ff56e2571d4751b.png
  2. 构造测试用例
    img_0da3979fb6abb5d04863aa0f95ed539f.png
    img_de573cf69eea435850ce40881aae7896.png
  3. 设置并发数
    img_d0a0c88f862cd0b9a75e5b15f8a7da4a.png
  4. 将测试计划保存成test.jmx, 默认保存到%{安装目录}/bin/下

执行

  1. 执行机器安装jdk
  2. 解压apache-jmeter-3.2.zip
  3. 将test.jmx拷到apache-jmeter/bin目录下(可其他目录)
  4. 运行./jmeter -n -t test.jmx -l 1.jtl
    • -n:非gui模式
    • -t:测试的jmx脚本
    • -l:测试结果保存在1.jtl

jmeter分布式压测

在单台执行机遇到瓶颈的时候,可采用分布式,进一步提高并发数。

  1. 选择一台机器做调度机(master),其他机器做执行机(slave);
  2. 执行时,master会将执行脚本发送到slave上,slave执行时完后,将所得的结果回传给master,master汇总后输出结果;

步骤

  1. slave的apache-jmeter/bin中执行
    ./jmeter-server -Djava.rmi.server.hostname=slave机器ip
  2. master的apache-jmeter/bin中执行
    ./jmeter -n -t test.jmx -l 1.jtl -R slave1_ip:1099,slave2_ip:1099
  • 使用了几个slave机器,这里就填几个,slave默认是使用1099端口
  • master和slave可同一台

jmeter使用参数化配置

有时候使用的参数并不固定,这时候就需要用到参数化配置
img_9726dcd32a624fde3607136b3cd05bc8.jpe
img_060ec04fddab852aed05ab2db0f14c35.png
img_3b3b33ecd7228fa02610306c7577a723.png
这样后,${domain}的值,就是test.txt里面每一行的内容,所以还要设置一个test.txt文件
注意点:

  1. 一般配置做相对路径,所以尽量和jmeter放一起,放在apache-jmeter/bin目录下面
  2. 分布式测试的时候,master只会发jmx脚本,不会发参数化文件,所以test.txt在每台slave都必须有文件

jmeter构造请求头参数

img_23fcb85c8658b7fc04dc5e776dd8f2f3.png
img_b4e049bdf7510f0e13089f00166280c9.png

相关实践学习
通过性能测试PTS对云服务器ECS进行规格选择与性能压测
本文为您介绍如何利用性能测试PTS对云服务器ECS进行规格选择与性能压测。
目录
相关文章
|
3月前
|
测试技术 持续交付 Apache
Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
【10月更文挑战第1天】Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
174 3
|
4月前
|
测试技术 数据库 UED
Python 性能测试进阶之路:JMeter 与 Locust 的强强联合,解锁性能极限
【9月更文挑战第9天】在数字化时代,确保软件系统在高并发场景下的稳定性至关重要。Python 为此提供了丰富的性能测试工具,如 JMeter 和 Locust。JMeter 可模拟复杂请求场景,而 Locust 则能更灵活地模拟真实用户行为。结合两者优势,可全面评估系统性能并优化瓶颈。例如,在电商网站促销期间,通过 JMeter 模拟大量登录请求并用 Locust 模拟用户浏览和购物行为,可有效识别并解决性能问题,从而提升系统稳定性和用户体验。这种组合为性能测试开辟了新道路,助力应对复杂挑战。
130 2
|
2月前
|
测试技术 持续交付 Apache
Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
91 3
|
2月前
|
缓存 测试技术 Apache
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
61 1
|
4月前
|
缓存 Java 测试技术
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
使用JMeter对项目各个接口进行压力测试,并对前端进行动静分离优化,优化三级分类查询接口的性能
123 10
谷粒商城笔记+踩坑(11)——性能压测和调优,JMeter压力测试+jvisualvm监控性能+资源动静分离+修改堆内存
|
3月前
|
缓存 测试技术 Apache
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
【10月更文挑战第1天】告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
89 4
|
4月前
|
移动开发 JSON Java
Jmeter实现WebSocket协议的接口测试方法
WebSocket协议是HTML5的一种新协议,实现了浏览器与服务器之间的全双工通信。通过简单的握手动作,双方可直接传输数据。其优势包括极小的头部开销和服务器推送功能。使用JMeter进行WebSocket接口和性能测试时,需安装特定插件并配置相关参数,如服务器地址、端口号等,还可通过CSV文件实现参数化,以满足不同测试需求。
280 7
Jmeter实现WebSocket协议的接口测试方法
|
4月前
|
测试技术 持续交付 Apache
Python性能测试新风尚:JMeter遇上Locust,性能分析不再难🧐
【9月更文挑战第10天】随着软件应用的不断扩展,性能测试成为确保系统稳定运行的关键环节。本文通过对比Apache JMeter和Locust,探讨了如何在Python环境中利用这两款工具挖掘更多性能测试潜力。JMeter是一款成熟且功能强大的开源工具,支持多种协议,适用于各种应用的测试;而Locust则基于Python,通过简单脚本模拟HTTP请求,更适合Web应用测试。
108 3
|
5月前
|
测试技术 持续交付 Apache
深度挖掘:Python性能测试中JMeter与Locust的隐藏技能🔍
【8月更文挑战第5天】随着软件规模扩大,性能测试对系统稳定性至关重要。Apache JMeter和Locust是两大主流工具,各有千秋。本文探索它们在Python环境下的进阶用法,挖掘更多性能测试潜力。JMeter功能强大,支持多种协议,可通过命令行模式执行复杂测试计划,并与Python集成实现动态测试数据生成。Locust基于Python,通过编写简洁脚本模拟HTTP请求,支持自定义请求及与Python库深度集成。掌握这些技巧可实现高度定制化测试场景,有效识别性能瓶颈,提升应用稳定性。
133 1
|
5月前
|
缓存 测试技术 Apache
告别卡顿!Python性能测试实战教程,JMeter&Locust带你秒懂性能优化💡
【8月更文挑战第5天】性能测试确保应用高负载下稳定运行。Apache JMeter与Locust是两大利器,助力识别解决性能瓶颈。本文介绍这两款工具的应用与优化技巧,并通过实战示例展示性能测试流程。首先,通过JMeter测试静态与动态资源;接着,利用Locust的Python脚本模拟HTTP请求。文中提供安装指南、命令行运行示例与性能优化建议,帮助读者掌握性能测试核心技能。
142 0