Mac电脑Jmeter集成到Jenkins,压测多个接口并生成测试报告
Jenkins支持的JDK版本17、21,通过java -version查看当前JDK版本,确认是否匹配
- 打开网址https://www.jenkins.io/download
点击下载,选择mac版本
- commend+空格打开终端,输入安装命令
brew install jenkins
安装完成后输入brew services start jenkins
启动jenkins
我在启动时报IO error,可尝试用管理者启动,命令:sudo brew services start jenkins
如果还不行,尝试使用另一个启动命令: brew services restart jenkins-lts
-
提示成功后,浏览器打开localhost:8080会进到登录页面
-
进入日志文件中,获取密码
cd /Users/xxxx/.jenkins/secrets
open initialAdminPassword
-
选择自定义,等待安装完成即可,如果有失败的直接跳过,后面可以再安装
-
创建管理员账号
-
设置URL地址
-
全部配置完成,进入jenkins主页面
以上就是Jenkins的下载和安装啦~~
下面是集成jmeter并生成测试报告的操作步骤
一、使用自由模式集成jmeter串行执行多个压测脚本并生成测试报告
-
点击【新建任务】,输入任务名称,选择“自由风格”,点击确认按钮
-
进入配置页面,选择【添加构建步骤-执行shell】
脚本如下,先进入到本地jmeter安装路径的bin目录下,把上次执行的结果csv文件和report全部删除,再执行第一个压测脚本,执行后将进程置于后台,并获取进程id,等待进程ID释放,执行完成后再启动第二个压测脚本,这样保证了每个脚本是独立执行互不干扰的
cd /Users/xxx/downloads/apache-jmeter-5.6.2/bin
find /Users/xxx/downloads/autotest/script/ -type f -name "*.csv" -exec rm {} \;
rm -rf /Users/xxx/downloads/autotest/script/report/*
./jmeter.sh -n -t /Users/xxx/downloads/autotest/script/script1.jmx -Jnum_threads=1 -Jramp_up_time=1 -Jduration=5 -l /Users/xxx/downloads/autotest/script/script1_result.csv -e -o /Users/xxx/downloads/autotest/script/report/script1
pid1=$!
wait $pid1
./jmeter.sh -n -t /Users/xxx/downloads/autotest/script/script2.jmx -Jnum_threads=20 -Jramp_up_time=1 -Jduration=2 -l /Users/xxx/downloads/autotest/script/script2_result.csv -e -o /Users/xxx/downloads/autotest/script/report/script2
-
Jnum_threads字段在jmx中通过表达式${__P(num_threads)}引用,其他字段同理,如图
-
添加构建后操作生成report,选择【增加构建后操作步骤-Publich HTML reports】
HTML directory to archive:填写本地存放测试报告的空文件夹路径
如果没有对应插件可以去下载,【系统管理-插件管理】
点击【可用插件】,搜索需要的插件,然后勾选安装即可
-
全部配置完成,点击保存,在项目目录下,点击【立即构建】即可执行脚本并生成测试报告,点击构建历史可进入对应详情页
-
点击【控制台输出】可查看日志
-
html格式的测试报告也会生成到指定文件夹下
经过多次测试发现:
Jmeter中聚合报告里的吞吐量计算存在误差,如果是单接口误差较小,多接口的话误差较大,不具备参考价值,因此需要手动计算,公式=线程数/平均响应时间,线程数是用户手动设置的Num
of Threads(users),并非测试报告中的样本数量
~~~~~~~~~~~~~~~~~~~~~~~~~~~~
二、 使用自由模式-参数化构建过程执行单个压测脚本并将结果写入本地CSV
在此方法中,将执行的详细结果写入csv中,通过添加构建后操作使用python脚本获取并计算正确的吞吐量
-
进入项目的配置页面,勾选【参数化构建过程-文本参数】,输入线程数名称如:Jnum_threads,可设置多个参数
-
选择【添加构建步骤-执行shell】 脚本中通过-Jnum_threads=${Jnum_threads}来获取上面设置的参数
cd /Users/xxx/downloads/apache-jmeter-5.6.2/bin
find /Users/xxx/downloads/autotest/script/ -type f -name "*.csv" -exec rm {} \;
rm -rf /Users/xxx/downloads/autotest/script/report/*
./jmeter.sh -n -t /Users/xxx/downloads/autotest/script/script1.jmx -Jnum_threads=${Jnum_threads} -Jramp_up_time=${Jramp_up_time} -Jduration=${Jduration} -l /Users/xxx/downloads/autotest/script/script1_result.csv -e -o /Users/xxx/downloads/autotest/script/report/script1
- 选择【增加构建后操作步骤-Execute scripts-执行shell】
构建步骤中已经通过命令-l /Users/xxx/downloads/autotest/script/script1_result.csv
将压测详细结果写入csv中,供这一步计算QPS使用
以下脚本将压测的接口地址、全部样本的状态码及个数、压测接口的平均响应时间、QPS打印到csv中
#!/usr/local/bin/python #使用which python命令获取python路径
# -*- coding: utf-8 -*-
import sys
import csv
import osdef read_csv(file_path):response_code_count = {} elapsed_sum = 0elapsed_count = 0url_count = 0# 根据Python版本选择不同的open函数参数if sys.version_info.major == 2:with open(file_path, 'rb') as file:reader = csv.DictReader(file)for row in reader:response_code = row['responseCode']elapsed = float(row['elapsed'])response_code_count[response_code] = response_code_count.get(response_code, 0) + 1#多接口情况下,获取指定接口url的个数,用于计算平均响应时间if row['URL'] == 'http://baidu.com:808/x/x/x':elapsed_sum += elapsedelapsed_count += 1url_count += 1elif sys.version_info.major == 3:with open(file_path, 'r', newline='', encoding='utf-8') as file:reader = csv.DictReader(file)for row in reader:response_code = row['responseCode']elapsed = float(row['elapsed'])response_code_count[response_code] = response_code_count.get(response_code, 0) + 1if row['URL'] == 'http://baidu.com:808/x/x/x':elapsed_sum += elapsedelapsed_count += 1url_count += 1return response_code_count, elapsed_sum, elapsed_count, url_countdef write_to_csv(file_path, data):with open(file_path, 'w') as file: writer = csv.writer(file)writer.writerow(["URL", "全部线程的状态码及个数","平均响应时间(S)","实际QPS"])writer.writerow(data)def main():#将压测的详细结果写入指定目录下的csv中file_path = '/Users/xxx/downloads/autotest/script/script1_result.csv'#将手动计算的结果写入指定目录的csv中output_file_path = '/Users/xxx/downloads/autotest/script/result.csv' # 输出环境变量的值num_threads_str = os.environ.get('Jnum_threads')target_throughtput = os.environ.get('Jtarget_throughtput')print("Value of NUM_THREADS:", num_threads_str)# 将 NUM_THREADS 转换为整数try:total_requests = int(num_threads_str)except (ValueError, TypeError):print("Error: NUM_THREADS environment variable is not a valid integer.")returnresponse_code_count, elapsed_sum, elapsed_count, url_count = read_csv(file_path)# 计算 QPSqps = 0avg_elapsed_seconds = Noneif elapsed_count > 0:avg_elapsed_seconds = elapsed_sum / elapsed_count / 1000 # 将毫秒转换为秒if avg_elapsed_seconds != 0:qps = total_requests / avg_elapsed_seconds# 将结果写入 CSV 文件avg_elapsed_seconds_formatted = '{:.2f}'.format(avg_elapsed_seconds)qps_formatted = '{:.2f}'.format(qps)#结果csv的要写入的具体值write_to_csv(output_file_path, ["http://baidu.com:808/x/x/x", response_code_count,avg_elapsed_seconds_formatted,qps_formatted])if __name__ == "__main__":main()
保存构建后选择【Build with Parameters】输入对应参数点击【Build】就开始构建了,最终的执行结果也会写会写入指定的csv中
相关文章:
Mac电脑Jmeter集成到Jenkins,压测多个接口并生成测试报告
Jenkins支持的JDK版本17、21,通过java -version查看当前JDK版本,确认是否匹配 打开网址https://www.jenkins.io/download 点击下载,选择mac版本 commend空格打开终端,输入安装命令brew install jenkins 安装完成后输入brew servi…...
redis-Hash
一,应用场景 Redis hash 是一个string类型的field和value的映射表,hash特别适合用于存储对象。Set就是一种简化的Hash,只变动key,而value使用默认值填充。 可以将一个Hash表作为一个对象进行存储,表中存放对象的信息。 二,命令 H…...
Kubernetes kafka系列 | Strimzi 部署kafka-bridge
Strimzi kafka集群部署直通车 一、kafka bridge 介绍 Kafka Bridge 是 Apache Kafka 生态系统中的一个工具或组件,用于实现 Kafka 与其他系统或协议之间的通信或集成。Kafka 本身是一个分布式事件流平台,广泛用于构建实时数据流水线和流式应用程序。然而…...
AR和VR如何改变客户体验?
How AR and VR are transforming customer experiences? How AR and VR are transforming customer experiences AR和VR如何改变客户体验 AR and VR technology was largely expedited by the past pandemic with at least 93.3 million and 58.9 million users r…...
微信小程序中实现埋点的方法
在小程序开发过程中,埋点是实现数据采集和用户行为分析的重要手段。通过埋点,我们可以获取用户在使用小程序时的各种操作信息,从而更好地了解用户行为特征,优化产品体验。下面将介绍如何在小程序中实现埋点,并通过代码示例进行说明。 一、埋点实现思路 小程序的埋点实现主要依…...
vue记事本渲染以及交互
以下是记事本的源码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>记事本</title><styl…...
Zookeeper中的脑裂
简单点来说,脑裂(Split-Brain) 就是比如当你的 cluster 里面有两个节点,它们都知道在这个cluster 里需要选举出一个 master。那么当它们两个之间的通信完全没有问题的时候,就会达成共识,选出其中一个作为 master。但是如果它们之间…...
【漏洞复现】金和OA XmlDeal.aspx XXE漏洞
0x01 产品简介 金和数字化智能办公平台(简称JC6)是一款结合了人工智能技术的数字化办公平台,为企业带来了智能化的办公体验和全面的数字化转型支持。同时符合国家信创认证标准,支持组织数字化转型,实现业务流程的数字化、智能化和协同化,提高企业竞争力。 0x02 漏洞概述…...
对比:React 还是 Vue
自己之前的开发栈一直是 Vue,对 Vue 的设计理念及底层实现原理算是颇有了解;随着公司技术迭代,近半年来开始接触&使用 React。 前面写了几篇关于 React 的文章,但大部分都是知识点以及开发过程问题的沉淀总结。 这篇文章想尝…...
ubuntu 20.04 SD 卡分区类型 msdos 改为 GPT 的方法
前言 默认 SD 卡分区是 FAT32 格式,为了用于嵌入式Linux ext4 文件系统,需要改为 ext4 文件系统,但是SD 卡分区类型默认是 msdos 类型,也就是 MBR 类型,不是 GPT 类型。 烧写 ext4 分区表,或者使用 ubuntu…...
Kubernetes(K8s)技术解析
1. K8s简介 Kubernetes(简称K8s)是一个开源的容器编排平台,旨在简化容器化应用程序的部署、扩展和管理。为开发者和运维人员提供了丰富的功能和灵活的解决方案,帮助他们更轻松地构建、部署和管理云原生应用程序。以下是关于Kubern…...
Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之十 简单颜色反转效果
Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之十 简单颜色反转效果 目录 Python 基于 OpenCV 视觉图像处理实战 之 OpenCV 简单实战案例 之十 简单颜色反转效果 一、简单介绍 二、简单颜色反转效果实现原理 三、简单颜色反转效果案例实现简单步骤 四、注…...
【ELK+Kafka+filebeat分布式日志收集】部署filebeat和Kibana(三)
filebeat下载 官网:https://www.elastic.co/cn/downloads/beats/filebeat 或者 cd /opt wget https://artifacts.elastic.co/downloads/beats/filebeat/filebeat-8.8.1-linux-x86_64.tar.gz依次执行如下命令...
二.音视频编辑-媒体组合-播放
引言 当涉及到音视频编辑时,媒体资源的提取和组合是至关重要的环节。在iOS平台上,AVFoundation框架提供了丰富而强大的功能,使得媒体资源的操作变得轻松而高效。从原始的媒体中提取片段,然后将它们巧妙地组合成一个完整的作品&am…...
前端安全-面试题(2024)
1. 面试总结话术: 前端常见的安全问题主要包括以下几种: 跨站脚本攻击(XSS):攻击者通过在目标网站注入恶意脚本,当用户访问网站时,恶意脚本会被执行,从而窃取用户信息或进行其他恶意操作。这种攻击通常利用表单提交、URL参数等方式注入脚本。存储型 xss 恶意代码存在数…...
CVE-2022-29405 Apache Archiva任意用户密码重置漏洞分析
Apache Archiva是一套可扩展的Artifact Repository管理系统。它能够与Maven,Continuum和ANT等构建工具完美结合。Archiva提供的功能包括:远程Repository代理,基于角色的安全访问管理,Artifact分发、维护、查询,生成使用…...
ssm框架配置文件例子
emmm。。。。 就是说,正常ssm的配置文件长啥样? 就最基础的? 贴一下,备忘吧。 第一个:applicationContext.xml <beans xmlns"http://www.springframework.org/schema/beans"xmlns:context"http…...
maven构建项目报错:Failure to find com.microsoft.sqlserver:sqljdbc4:jar:4.0 in
背景 今天在项目里面查询sqlserver的数据库的时候,本地maven中引入依赖: <dependency><groupId>com.microsoft.sqlserver</groupId><artifactId>sqljdbc4</artifactId><version>4.0</version></dependenc…...
已解决rabbitmq AMQPConnectionClosedException:管道破裂或连接关闭异常的正确解决方法,亲测有效!!!
已解决rabbitmq AMQPConnectionClosedException:管道破裂或连接关闭异常的正确解决方法,亲测有效!!! 目录 一、问题分析 二、报错原因 三、解决思路 四、解决方法 五、总结 博主v:XiaoMing_Java 一、…...
Excel 隔几行批量插入空白行
例如如下表格,每隔6行插入一行数据: 1)第7个单元格输入1 2)选中6个单元格,然后双击填充数据: 3)F5 找到常量 Ctrlshift 复制插入的数据,然后选中数据 按F5,定位到空值...
2024年04月在线IDE流行度最新排名
点击查看最新在线IDE流行度最新排名(每月更新) 2024年04月在线IDE流行度最新排名 TOP 在线IDE排名是通过分析在线ide名称在谷歌上被搜索的频率而创建的 在线IDE被搜索的次数越多,人们就会认为它越受欢迎。原始数据来自谷歌Trends 如果您相…...
如何通过Elasticsearch实现搜索的关键词达到高亮的效果
高亮 首先介绍一下什么是搜索的关键词达到高亮的效果,如图所示 当在百度里面搜索elasticsearch的时候,可以看到出现的搜索结果里面elasticsearch这个关键词明显与其他的条文不一样,用红颜色凸显了“高亮效果”。当我们想要在自己的项目里面…...
真实sql注入以及小xss--BurpSuite联动sqlmap篇
前几天漏洞检测的时候无意发现一个sql注入 首先我先去网站的robots.txt去看了看无意间发现很多资产 而我意外发现admin就是后台 之后我通过基础的万能账号密码测试or ‘1‘’1也根本没有效果 而当我注入列的时候情况出现了 出现了报错,有报错必有注入点 因此我…...
Java类和对象练习题
练习一 下面代码的运行结果是() public static void main(String[] args){String s;System.out.println("s"s);} 解析:本题中的代码不能编译通过,因为在Java当中局部变量必须先初始化,后使用。所以此处编译不…...
Qt 实现简易的视频播放器,功能选择视频,播放,暂停,前进,后退,进度条拖拉,视频时长显示
1.效果图 2.代码实现 2.1 .pro文件 QT core gui multimedia multimediawidgets 2.2 .h文件 #ifndef VIDEOPLAYING_H #define VIDEOPLAYING_H#include <QWidget> #include<QFileDialog>#include<QMediaPlayer> #include<QMediaRecorder> #in…...
vue基础教程(6)——构建项目级登录页
同学们可以私信我加入学习群! 正文开始 前言一、创建首页二、登录页代码讲解三、对应的vue知识点:四、附件-各文件代码总结 前言 前面我们已经把vue自带的页面删除,也搭建了最简单的router路由,下面就可以真正开发我们自己的项目…...
C++宝强越狱1.0.6版本
没啥好说的,更新了一关,上代码 #include"bits/stdc.h" #include"Windows.h" #define KEY_DOWN(VK_NONAME) ((GetAsyncKeyState(VK_NONAME) & 0x8000) ? 1:0) using namespace std; int w3,s3,a3,d3; bool nfalse,iptrue,mfals…...
构建高可用性数据库架构:深入探索Oracle Active Data Guard(ADG)
随着企业数据规模的不断增长和业务的复杂化,数据库的高可用性和可靠性变得尤为重要。Oracle Active Data Guard(ADG)作为Oracle数据库提供的一种高可用性解决方案,在实时备份和灾难恢复方面发挥着重要作用。本文将深入探讨ADG的原…...
记录-rosbag的处理
https://blog.csdn.net/qq_39607707/article/details/123716925 https://blog.csdn.net/weixin_51060040/article/details/126612496...
用Wireshark解码H.264
H264,你不知道的小技巧-腾讯云开发者社区-腾讯云 这篇文章写的非常好 这里仅做几点补充 init.lua内容: -- Set enable_lua to false to disable Lua support. enable_lua trueif not enable_lua thenreturn end-- If false and Wireshark was start…...
wordpress文中广告/最新国际军事动态
源码编号:D-E48 点击查看(分类规则) 项目名称:基于SSM的校园运动会管理系统 源码作者:霹雳本人开发 论文作者:逍遥游撰写 当前版本:V2.0版本 难度等级:✩✩✩ 复杂程度&#x…...
企业网站创建需要多种语言吗/品牌传播推广方案
神经网络中的epoch、batch、batch_size、iteration的理解 下面说说这三个区别: (1)batchsize:批大小。在深度学习中,一般采用SGD训练,即每次训练在训练集中取batchsize个样本训练; ࿰…...
网站开发开什么票/培训网址
http://www.elecfans.com/tongxin/123/20180103610476.html 经常看到RS485和MODBUS写在一起,它们的区别和联系? RS485是一个物理接口,简单的说是硬件。 MODBUS是一种国际标准的通讯协议,用于不同厂商之间的设备交换数据࿰…...
重庆可做网站 APP/宁波seo智能优化
1.丢弃小数部分,保留整数部分 parseInt 2.向上取整,有小数就整数部分加1 Math.ceil 3.四舍五入 Math.round 4.向下取整 Math.floor 5.oninput "valuevalue.replace(/[^\d]/g,)" //只能输入数字 6.oninput "valuevalue.replace(/[^0-9.]/g,)" //只能输入…...
电商网站那些功能用到静态化功能/seo技术学院
前段时间实现了估计参数的有限混合正态分布EM算法,虽然是别人的东西拿来借鉴,不过还是要自己笔记一下,以后才能说得出口 直接说实际解决问题,现有n个数据,每个属性都有m个属性值,比如一个人可能有身高、工资…...
顺德网站建设公司/浏览器老是出现站长工具
上周我遇到了最近的Authorize.net SSL证书失效debacle。我终于让curl接受了他们的证书:$ curl -Iv https://secure.authorize.net...* SSL certificate verify ok....但python仍然拒绝了它的请求:>>> requests.get(https://secure.authorize.ne…...