• 压力测试工具介绍


    可以通过压力测试对网站及服务器性能进行高压测试,暴露出其所存在的问题。从而对服务器及网站进行调整和优化。
    注意在进行压力测试时要在单独的机器上进行不要在待测服务器上进行。目前主要有apache的ab、http_load、webbench、Siege等。

    一、http_load

    程序非常小,解压后也不到100K

    http_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载。但是它不同于大多数压力测试工

    具,它可以以一个单一的进程运行,一般不会把客户机搞死。还可以测试HTTPS类的网站请求。

    下载并编译安装:wget http://www.acme.com/software/http_load/http_load-09Mar2016.tar.gz
    tar zxf http_load-09Mar2016.tar.gz
    cd http_load-09Mar2016
    make && make install

    命令格式:http_load  -p 并发访问进程数  -s 访问时间  需要访问的URL文件

    参数其实可以自由组合,参数之间的选择并没有什么限制。比如你写成http_load -parallel 5 -seconds

    300 urls.txt也是可以的。我们把参数给大家简单说明一下。
    -parallel 简写-p :含义是并发的用户进程数。
    -fetches 简写-f :含义是总计的访问次数
    -rate    简写-p :含义是每秒的访问频率
    -seconds简写-s :含义是总计的访问时间

    准备URL文件:urllist.txt,文件格式是每行一个URL,URL最好超过50-100个测试效果比较好.文件格式

    例如:

    http_load -p 30 -s 60  urllist.txt
    参数了解了,我们来看运行一条命令来看看它的返回结果

    二、webbench

    webbench是Linux下的一个网站压力测试工具,最多可以模拟3万个并发连接去测试网站的负载能力。下载

    地址可以到google搜,我这里给出一个
    下载地址:http://soft.vpser.net/test/webbench/webbench-1.5.tar.gz
    这个程序更小,解压后不到50K,呵呵
    安装非常简单
    wget http://soft.vpser.net/test/webbench/webbench-1.5.tar.gz
    tar zxvf webbench-1.5.tar.gz
    cd webbench-1.5
    make && make install
    会在当前目录生成webbench可执行文件,直接可以使用了

    用法:
    webbench -c 并发数 -t 运行测试时间 URL
    如:
    webbench -c 5000 -t 120 http://www.google.com

    三、ab
    ab是apache自带的一款功能强大的测试工具
    安装了apache一般就自带了,
    用法可以查看它的说明

    四、Siege
    一款开源的压力测试工具,可以根据配置对一个WEB站点进行多用户的并发访问,记录每个用户所有请求过程的相应时间,并在一定数量的并发访问下重复进行。
    官方:http://www.joedog.org/
    Siege下载:wget http://download.joedog.org/siege/siege-4.0.2.tar.gz
    解压:
    tar zxf siege-4.0.2.tar.gz
    进入解压目录:
    cd siege-4.0.2
    安装:
    ./configure
    make && make install

    使用
    siege -c 200 -r 10 -f example.url
    -c是并发量,-r是重复次数。 url文件就是一个文本,每行都是一个url,它会从里面随机访问的。

    example.url内容:

    http://www.google.com
    http://www.baidu.com

    结果说明
    Lifting the server siege… done.
    Transactions: 3419263 hits //完成419263次处理
    Availability: 100.00 % //100.00 % 成功率
    Elapsed time: 5999.69 secs //总共用时
    Data transferred: 84273.91 MB //共数据传输84273.91 MB
    Response time: 0.37 secs //相应用时1.65秒:显示网络连接的速度
    Transaction rate: 569.91 trans/sec //均每秒完成 569.91 次处理:表示服务器后
    Throughput: 14.05 MB/sec //平均每秒传送数据
    Concurrency: 213.42 //实际最高并发数
    Successful transactions: 2564081 //成功处理次数
    Failed transactions: 11 //失败处理次数
    Longest transaction: 29.04 //每次传输所花最长时间
    Shortest transaction: 0.00 //每次传输所花最短时间

    五。wrk 压力测试

    [root@centos ~]# wrk -t 2 -c 50 -d 20 --latency http://localhost:5000

    参数说明:

    -t 需要模拟的线程数
    -c 需要模拟的连接数
    -d 测试的持续时间
    --timeout 超时的时间
    --latency 显示延迟统计

    结果显示说明:
    Latency:响应时间
    Req/Sec:每个线程每秒钟的完成的请求数
    Avg:平均
    Max:最大
    Stdev:标准差

  • 相关阅读:
    androidstudio配置http proxy以及配置gradle
    发布jar到docker的方法
    idea直接发布项目到docker中
    安卓启动相机报错android.os.FileUriExposedException: file:///storage/emulated/0/
    centos 7.4搭建Harbor、push docker镜像以及常见错误
    dock的卸载与安装
    centos部署Kubernetes(k8s)集群
    Logback将日志输出到Kafka配置示例
    JavaScript设计模式 Item 5 --链式调用
    你不知道的JavaScript--Item27 异步编程异常解决方案
  • 原文地址:https://www.cnblogs.com/geekmao/p/8184745.html
Copyright © 2020-2023  润新知