当前位置: 首页 > news >正文

开封建设教育协会网站玉山电商网站建设

开封建设教育协会网站,玉山电商网站建设,seo优化网络公司,代运营主要做什么为什么需要分布式? 在工作中经常需要对一些关键接口做高QPS的压测,JMeter是由Java 语言开发,没创建一个线程(虚拟用户),JVM默认会为每个线程分配1M的堆栈内存空间。受限于单台试压机的配置很难实现太高的并…

为什么需要分布式?

在工作中经常需要对一些关键接口做高QPS的压测,JMeter是由Java 语言开发,没创建一个线程(虚拟用户),JVM默认会为每个线程分配1M的堆栈内存空间。受限于单台试压机的配置很难实现太高的并发。所以,通过JMeter实现分布式,可以整合多台主机的硬件资源,实现同时对被测试接口进行压力测试。

Jmeter分布式测试环境中有两个角色:Master 和 Slaves

  • Master节点:向参与的Slaves节点发送测试脚本,并聚合Agent节点的执行结果。

  • Slaves节点:接收并执行Master节点发送过来的测试脚本,并将执行结果返回给Master。

为什么要使用docker?

如果要分布式联动每台主机,就要求每台主机都要有JMeter环境(JDK + JMeter),如果利用docker就可以通过docker管理 JMeter环境,简单的拉取镜像,启动容器即可。进一步讲,利用k8s、云服务可以无限的扩容JMeter试压机,理论上多少的并发用户都可以模拟。

准备工作

  • JDK:启动 JMeter 工具需要
$ brew install openjdk@11
  • JMeter: 编写JMeter脚本
    Index of /dist/jmeter/binaries

编写一个简单的脚本。

  • docker: 通过doker创建容器。
$ docker pull runcare/jmeter-master
$ docker pull runcare/jmeter-slave
  • 查看docker镜像
$ docker imagesREPOSITORY              TAG        IMAGE ID       CREATED         SIZE
runcare/jmeter-master   latest     e052a8cd8680   3 years ago     326MB
runcare/jmeter-slave    latest     05c7ba96d97d   3 years ago     326MB

请记住 jmeter-master 的镜像ID e052a8cd8680,后面会用到。

分布式压测使用

  • 启动 slave 节点。
    假设有两台主机,可以启动两个slave。
$ docker run -it -d --name slave01 runcare/jmeter-slave
$ docker run -it -d --name slave02 runcare/jmeter-slave
  • 查看启动的容器
$ docker psCONTAINER ID   IMAGE                  COMMAND                   CREATED             STATUS             PORTS                 NAMES
b270636a7741   runcare/jmeter-slave   "/bin/sh -c 'jmeter-…"   43 seconds ago      Up 42 seconds      1099/tcp, 60001/tcp   slave01
2584c7fef5f8   runcare/jmeter-slave   "/bin/sh -c 'jmeter-…"   52 seconds ago      Up 50 seconds      1099/tcp, 60001/tcp   slave02
  • 发送压测脚本到 slave
$ result=`date +"%Y%m%d%H%M%S"` && docker run --rm -v /Users/fnngj/zhpro/script:/data e052a8cd8680 jmeter -n -t /data/baidu_script.jmx -l /data/$result.jtl -j /data/$result.log -e -o /data/$result -R 172.17.0.2,172.17.0.3

参数说明

result=date +"%Y%m%d%H%M%S"`: 指定测试结果的名称,以当前日期时间命名。

/Users/fnngj/zhpro/script : 压测脚本的目录,测试结果也会存放到该目录下。

baidu_script.jmx : 压测脚本的名称,存放于 /Users/fnngj/zhpro/script目录下。

e052a8cd8680 : jmeter-master 的镜像ID。

172.17.0.2,172.17.0.3 : 两台 slave 的IP 地址。

测试结果

  • 执行完的目录
$ pwd
/Users/fnngj/zhpro/script$ ls
20230707005328     20230707005328.jtl 20230707005328.log baidu_script.jmx
  • 查看报告

进入20230707005328 目录,点击 index.html 文件,可以看到压测的结果。

最后

如果你想学习自动化测试,那么下面这套视频应该会帮到你很多

Python接口自动化测试零基础入门到精通(2023最新版)

http://www.yayakq.cn/news/729338/

相关文章:

  • 南京市住房和城乡建设网站phpmysql网站模板
  • 做网站需要备案wordpress插件开发教程 pdf
  • 个人微信小程序免费制作平台昆明做网站词排名优化
  • 公司首页模板网站建设优化公司哪家好
  • 电子商务网站盈利模式中山网约车资格证报名地点
  • 郑州响应式建站代刷网站只做软件
  • 怎么做网站呢高邑网站建设
  • 网页版qq怎么登陆黄冈seo推广优势
  • 网站源码分享网wordpress评论贴图表情字体
  • 网站建设的实验的结论网站开发找哪家
  • 网站建设最好用什么语言怎么编写app软件
  • 深圳建筑网站门户cms系统
  • 不是固定ip如何做网站丽水市建设工程招标网站
  • 如何注册网站的名字学网站开发培训
  • alt网站标签怎么做深圳做网站网络公司
  • 保定网站建设浩森宇特下载个网上销售网站
  • 怎样装修公司网站广东省建设行业统一身份认证平台
  • 一个网站添加多个网址广州网站建设:
  • 设计免费素材网站.net电商网站全站开发
  • 医疗网站模板泸西网站建设
  • 网站建设兼职在哪找企业网站设计的基本内容包括哪些
  • 直播做ppt的网站有哪些网站建设是属于软件吗
  • 建立论坛网站网站做百度推广要多少钱
  • 抚顺网站建设wordpress 博客地址
  • 做网站的公司排名长沙人才招聘网最新招聘2022
  • 搭建网站需要钱吗网站优化排名易下拉系统
  • 合肥市建设工程劳务分包合同备案表在哪个网站下载2345影视大全可以放心下载吗
  • 网站被谷歌收录新浪sae部署wordpress配置
  • 南京凯盛建设集团有限公司网站最具口碑的企业网站建设
  • 苏州建网站哪个好百度营销大学