压测工具使用

  |  

Apache Bench

Apache Bench 简介
ApacheBench 是 Apache 服务器自带的一个 web 压力测试工具,简称 ab。ab 又是一个命令行工具,对发起负载的本机要求很低,根据 ab 命令可以创建很多的并发访问线程,模拟多个访问者同时对某一 URL 地址进行访问,因此可以用来测试目标服务器的负载压力。总的来说 ab 工具小巧简单,上手学习较快,可以提供需要的基本性能指标,但是没有图形化结果,不能监控。

  1. 下载

    在这里插入图片描述

  2. 解压到本地就可以直接使用,使用如下
    .\bin\abs.exe -c 1 -n 1 -p .\body.txt -T application/json http://127.0.0.1:3000/testing/nium/api/v1/authorization

在这里插入图片描述
body.txt 就是请求的 body 参数
在这里插入图片描述

  1. 参数介绍:

参数说明:
格式:ab [options] [http://]hostname[:port]/path

-n requests Number of requests to perform //本次测试发起的总请求数
-c concurrency Number of multiple requests to make //一次产生的请求数(或并发数)
-t timelimit Seconds to max. wait for responses //测试所进行的最大秒数,默认没有时间限制。
-r Don’t exit on socket receive errors. // 抛出异常继续执行测试任务
-p postfile File containing data to POST //包含了需要 POST 的数据的文件,文件格式如“p1=1&p2=2”.使用方法是 -p 111.txt

-T content-type Content-type header for POSTing
//POST 数据所使用的 Content-type 头信息,如 -T “application/x-www-form-urlencoded” 。 (配合-p)

-v verbosity How much troubleshooting info to print
//设置显示信息的详细程度 – 4 或更大值会显示头信息, 3 或更大值可以显示响应代码(404, 200 等), 2 或更大值可以显示警告和其他信息。

-V 显示版本号并退出。
-C attribute Add cookie, eg. -C “c1=1234,c2=2,c3=3” (repeatable)
//-C cookie-name=value 对请求附加一个 Cookie:行。 其典型形式是 name=value 的一个参数对。此参数可以重复,用逗号分割。
提示:可以借助 session 实现原理传递 JSESSIONID 参数, 实现保持会话的功能,如-C ” c1=1234,c2=2,c3=3, JSESSIONID=FF056CD16DA9D71CB131C1D56F0319F8″ 。

-w Print out results in HTML tables //以 HTML 表的格式输出结果。默认时,它是白色背景的两列宽度的一张表。
-i Use HEAD instead of GET

  1. 返回介绍
    Document Path:测试页面
    Document Length: 页面大小
    Concurrency Level: 测试的并发数
    Time taken for tests:整个测试持续的时间
    Complete requests:完成的请求数量
    Failed requests: 失败的请求数量
    Write errors: 0
    Total transferred: 整个过程中的网络传输量
    HTML transferred: 整个过程中的 HTML 内容传输量
    Requests per second: 最重要的指标之一,相当于 LR 中的每秒事务数,后面括号中的 mean 表示这是一个平均值
    Time per request: 最重要的指标之二,相当于 LR 中的平均事务响应时间,后面括号中的 mean 表示这是一个平均值
    Time per request: 每个连接请求实际运行时间的平均值
    Transfer rate: 平均每秒网络上的流量,可以帮助排除是否存在网络流量过大导致响应时间延长的问题

  2. 参考文档

jmeter

  1. jmeter 简介
    Apache JMeter 是 Apache 组织开发的基于 Java 的压力测试工具。用于对软件做压力测试,它最初被设计用于 Web 应用测试,但后来扩展到其他测试领域。 可以用于测试静态和动态资源,例如静态文件、CGI 脚本、Java 对象、数据库、FTP 服务器 等等。JMeter 可以用于对服务器、网络或对象模拟巨大的负载,来自不同压力类别下测试它们的强度和分析整体性能。

  2. jmeter 安装
    由于 Jmeter 是基于 java 开发,首先需要下载安装 JDK (目前 JMeter 只支持到 Java 8,尚不支持 Java 9)。
    官网下载地址:http://jmeter.apache.org/download_jmeter.cgi
    下载完成后解压 zip 包
    启动 JMeter,双击 JMeter 解压路径(apache-jmeter-3.3\bin)bin 下面的 jmeter.bat 即可
    Jmeter 是支持中文的,启动 Jmeter 后, 点击 Options -> Choose Language 来选择语言

  3. jmeter 使用
    (1) 添加线程组
    线程数:虚拟用户数,用于并发测试。
    Ramp-Up Period(in seconds)准备时长:设置的虚拟用户数需要多长时间全部启动。如果线程数为 10,准备时长为 2,那么需要 2 秒钟启动 10 个线程,也就是每秒钟启动 5 个线程。
    循环次数:每个线程发送请求的次数。如果线程数为 10,循环次数为 100,那么每个线程发送 100 次请求。总请求数为 10*100=1000 。如果勾选了“永远”,那么所有线程会一直发送请求,一到选择停止运行脚本。
    (2) 在线程组下添加测试的请求类型,例如 http 请求、TCP 请求等,注意一些请求可能需要添加额外的插件才能实现(例如 UDP)。下面以常用的 http 请求为例。
    协议:向目标服务器发送 HTTP 请求协议,可以是 HTTP 或 HTTPS,默认为 HTTP 。
    服务器名称或 IP :HTTP 请求发送的目标服务器名称或 IP 。
    端口号:目标服务器的端口号,默认值为 80 。
    方法:发送 HTTP 请求的方法,可用方法包括 GET、POST、HEAD、PUT、OPTIONS、TRACE、DELETE 等。
    路径:目标 URL 路径(URL 中去掉服务器地址、端口及参数后剩余部分)
    Content encoding :编码方式,默认为 ISO-8859-1 编码,可以配置为 utf-8
    在这里插入图片描述
    在这里插入图片描述
    (3)添加监听器-查看结果树

  4. 聚合报告详解:
    Label:每个 JMeter 的 element(例如 HTTP Request)都有一个 Name 属性,这里显示的就是 Name 属性的值。
    #Samples:请求数——表示这次测试中一共发出了多少个请求,如果模拟 10 个用户,每个用户迭代 10 次,那么这里显示 100。
    Average:平均响应时间——默认情况下是单个 Request 的平均响应时间(ms),当使用了 Transaction Controller 时,以 Transaction 为单位显示平均响应时间。
    Median:中位数,也就是 50% 用户的响应时间
    90% Line:90% 用户的响应时间
    Min:最小响应时间
    Max:最大响应时间
    Error%:错误率——错误请求数/请求总数
    throughput:吞吐量——默认情况下表示每秒完成的请求数(Request per Second)
    KB/Sec:每秒从服务器端接收到的数据量,相当于 LoadRunner 中的 Throughput/Sec

文章目录
  1. 1. Apache Bench
  2. 2. jmeter