`
呼延浩云
  • 浏览: 85370 次
  • 性别: Icon_minigender_1
  • 来自: 北京
博客专栏
69e5c1d2-1364-320a-a0f2-0de5143310d8
互联网的那点事
浏览量:11042
社区版块
存档分类
最新评论

怎么做服务器压力测试?

阅读更多

项目做好了,能不能顺利上线?

一般来说我们需要做一下压力测试来判断。比如该项目上线后预计每天一百万的接口访问量,并且访问时段主要集中在早八点到晚八点,那么平均下来 RPS 大约是 22 次左右,不过用户的访问量通常不会很平均,假设峰值流量是平均流量的 3 到 5 倍的话,那么我们可以推断出项目要想顺利上线,RPS 至少应该达到 66+ 次,110+ 次更好。

 

由此可见上线前用压力测试工具测试 RPS 是一个很重要的环节。

 

下面小编给大家介绍几款Web服务器性能压力测试工具。

 

一、先说花钱的

没有钱解决不了的事,如果有,那一定是钱不够。

 

1、阿里云推出了一款测压服务:阿里云性能测试PTS

 

阿里云的性能测试PTS无需安装软件;脚本场景监控简单化,省时、省力;分布式并发压测,施压能力无上限;快速大规模集群扩容、支持几十万用户及百万级TPS性能压测;可模拟海量用户的真实业务场景,全方位验证业务站点的性能、容量和稳定性。

PTS 广泛应用于各种压力测试和性能测试场景,包括但不限于以下场景:



 

详细参考《如何在一分钟内发起压测?

2、腾讯云也有一款测压服务:腾讯云压测大师

WeTest 压测大师(Load Master,LM)是简单易用的自动化性能测试平台,为用户提供测试框架及压测环境、创建虚拟机器人模拟产品多用户并发场景,支持 http 或https 协议,包括 Web/H5 网站、移动应用、API 、游戏等主流压测场景,适用于产品发布前及运营中的服务器压力测试及性能优化。

> 详细参考《如何在一分钟内发起压力测试?

二、再说不花钱的

 

1、http_load

 

程序非常小,解压后也不到100K
http_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载。
但是它不同于大多数压力测试工具,它可以以一个单一的进程运行,一般不会把客户机搞死。
还可以测试HTTPS类的网站请求。


下载地址:http_load-12mar2006.tar.gz

 

安装很简单

 

#tar zxvf http_load-12mar2006.tar.gz
#cd http_load-12mar2006
#make && make install

 

基本用法:

 

http_load  -p 并发访问进程数  -s 访问时间  需要访问的URL文件

 

参数其实可以自由组合,参数之间的选择并没有什么限制。

比如你写成http_load  -parallel  5  -seconds  300  urllist.txt也是可以的。

我们把参数给大家简单说明一下。

 

-parallel   简写-p :含义是并发的用户进程数。
-fetches   简写-f :含义是总计的访问次数

 

-rate        简写-p :含义是每秒的访问频率
-seconds 简写-s :含义是总计的访问时间

 

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

 

文件格式如下:

https://iil.ink/m6c5a
https://iil.ink/qiyeji2zhe
https://iil.ink/rds85zhe
https://iil.ink/txljsl
https://iil.ink/gamedun
https://iil.ink/duanxinsms
https://iil.ink/alicdn

 

例如:

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

 

结果分析:

  1. 294 fetches, 30 max parallel, 3.83835e+06 bytes, in 60.0026 seconds
    说明在上面的测试中运行了294个请求,最大的并发进程数是30,总计传输的数据是3.83835e+06bytes,运行的时间是60.0026秒
  2. 13055.6 mean bytes/connection
    说明每一连接平均传输的数据量3.83835e+06/294=13055.6
  3. 4.89979 fetches/sec, 63969.7 bytes/sec
    说明每秒的响应请求为4.89979,每秒传递的数据为63969.7 bytes/sec
  4. msecs/connect: 312.009 mean, 1319.57 max, 209.994 min
    说明每连接的平均响应时间是312.009 msecs,最大的响应时间1319.57 msecs,最小的响应时间209.994 msecs
  5. msecs/first-response: 1191.01 mean, 10212.4 max, 220.78 min
  6. HTTP response codes: 
  7. 200  –  127 

code 502  –  166
说明打开响应页面的类型。
如果403的类型过多,那可能要注意是否系统遇到了瓶颈。

 

特殊说明:
测试结果中主要的指标是 fetches/sec、msecs/connect 这个选项,即服务器每秒能够响应的查询次数。
用这个指标来衡量性能。似乎比 apache的ab准确率要高一些,也更有说服力一些。
Qpt-每秒响应用户数和response time,每连接响应用户时间。
测试的结果主要也是看这两个值。
当然仅有这两个指标并不能完成对性能的分析,我们还需要对服务器的cpu、men进行分析,才能得出结论。

 

2、webbench

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


下载地址可以到google搜,我这里给出一个
下载地址:webbench-1.5.tar.gz
这个程序更小,解压后不到50K,呵呵
安装非常简单

 

#tar zxvf webbench-1.5.tar.gz
#cd webbench-1.5
#make && make install

 

会在当前目录生成webbench可执行文件,直接可以使用了
用法:webbench -c 并发数 -t 运行测试时间 URL

 

例如:

 

#webbench -c 1000 -t 130 https://iil.ink/m6c5a

 

3、apache bench(主要是用来测试apache的)

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

 

#./ab

 

参数众多,一般我们用到的是-n 和-c
例如:

 

#webbench -c 1000 -t 130 https://iil.ink/m6c5a

 

这个表示同时处理1000个请求并运行130次https://iil.ink/m6c5a路径。

 

4、Siege

一款开源的压力测试工具,可以根据配置对一个WEB站点进行多用户的并发访问,记录每个用户所有请求过程的相应时间,并在一定数量的并发访问下重复进行。

Siege官方:http://www.joedog.org/

Siege下载:siege-latest.tar.gz

Siege解压并安装:

# tar -zxvf siege-latest.tar.gz
# cd siege-latest/
#./configure
#make
#make install

Siege使用:

#siege -c 100 -r 10 -f site.url

 

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

 

site.url内容:

https://iil.ink/m6c5a
https://iil.ink/qiyeji2zhe
https://iil.ink/rds85zhe
https://iil.ink/txljsl
https://iil.ink/gamedun

结果说明:

Transactions: 550 hits //完成550次处理
Availability: 55.00 % //55.00 % 成功率
Elapsed time: 31.32 secs //总共用时
Data transferred: 1.15 MB //共数据传输1.15 MB
Response time: 3.04 secs //显示网络连接的速度
Transaction rate: 17.56 trans/sec //均每秒完成 17.56 次处理:表示服务器后
Throughput: 0.04 MB/sec //平均每秒传送数据
Concurrency: 53.44 //实际最高并发数
Successful transactions: 433 //成功处理次数
Failed transactions: 450 //失败处理次数
Longest transaction: 15.50 //每次传输所花最长时间
Shortest transaction: 0.42 //每次传输所花最短时间

 

总结:

相对于花钱的,不花钱的限制肯定多一些,而且还要费时费力的配置。对于有大流量企业来讲,钱已经不是事儿了,所以能用钱解决的问题尽量别耽误时间。这里只讲一下几种工具,方便大家测试。

原文:怎么做服务器压力测试?

  • 大小: 58.6 KB
1
0
分享到:
评论

相关推荐

    SMTP/POP/IMAP 服务器压力测试工具

    SMTP服务器压力测试工具通常会模拟大量的邮件发送情景,检查服务器在高负载下处理邮件的能力,包括连接速度、发送速率以及错误处理。这有助于发现潜在的性能瓶颈或稳定性问题。 POP服务器压力测试则关注邮件的下载...

    jmeter mqtt服务器压力测试

    《JMeter MQTT服务器压力测试详解》 在信息技术领域,性能测试是确保系统稳定性和可靠性的重要环节,特别是对于物联网(IoT)应用中的消息传递协议,如MQTT(Message Queuing Telemetry Transport)。JMeter,一个...

    服务器压力测试真实计划

    服务器 压力测试 方案 pdf 文件 密码:sage

    几个linux服务器性能测试工具,服务器压力测试

    整理了几个比较实用,功能比较强大的性能测试工具供亲们下载,虽然网络上都对每个工具做了详细的功能介绍和文档说明,但分得很散,所以, 在此本人将各个比较实用的服务器性能测试工具集中起来,方便开发人员有针对...

    UDP服务器并发压力测试工具

    该工具采用QT+ACE实现,应用平台为windows,采用ACE practor模式封装的windows下的完成端口机制,保证并发测试的效果,每秒中我的电脑(4核,4G内存 3.2G主频,100M网卡)可以发送2800个...界面用Qt做的,简单实用。

    使用jmeter做ws压力测试

    这篇博客文章“使用jmeter做ws压力测试”将深入探讨如何利用JMeter进行Web服务的压力测试。 首先,了解JMeter的基本结构至关重要。JMeter由线程组、采样器、监听器、断言、定时器、配置元件等组件构成。线程组模拟...

    手机游戏如何做压力测试

    压力测试是其中重要的环节,它的目的是为了检验游戏服务器在面对大量用户请求时的承载力和稳定性。进入2015年以后,随着GAPS技术的出现和应用,手游的压力测试方法发生了显著变化。 首先,需要了解压力测试的概念。...

    VC 6.0实现TCP服务器压力测试附源代码.rar

    VC 6.0实现TCPServer TCP服务器压力测试程序附源代码,作者:代码客(卢益贵) 。程序中对突破最大连接办法和G-Sockets(压力测试工具源码)进行了公开,内部包括了一个基于完成端口的Tcp客户端通讯模块,编写代码时做...

    Loadrunner Webservice压力测试

    【Loadrunner Webservice压力测试】 LoadRunner是一款强大的性能测试工具,尤其在Web服务(Webservice)的压力测试方面表现卓越。本文将详细介绍如何使用LoadRunner进行Webservice的压力测试,结合具体的步骤示例,...

    网站 REST 服务器 压力负载强度等多项测试工具 德国Webserver Stress Tool 8 企业版(全功能自由软件无需注册授权)

    想对自己的网站和REST服务器进行压力、负载、强度等多种测试,发现有...缺点:由于不是在线方式,没有在线的分布式资源,因此不能做分布式压力测试,与真实的网络环境尚有些差距,但做为一种参考测试,完全没有问题。

    Chariot交换机压力测试工具(含教程

    Chariot是一款强大的网络性能分析和压力测试工具,尤其在评估和优化交换机性能方面具有显著优势。它通过模拟多种网络负载,帮助IT专业人员理解网络在高压力环境下的表现,确保交换机和其他网络设备在繁忙的工作场景...

    jmeter3.2压力测试

    用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域。 它可以用于测试静态和动态资源,例如静态文件、Java 小服务程序、CGI 脚本、Java 对象、数据库、FTP 服务器, 等等。JMeter 可以...

    Apache JMeter 3.3软件 服务器压力测试(包安装配置教程)

    用于对软件做压力测试,它最初被设计用于Web应用测试但后来扩展到其他测试领域。 它可以用于测试静态和动态资源例如静态文件、Java小服务程序、CGI脚本、Java 对象、数据库, FTP服务器, 等等。JMeter 可以用于对...

    德国 服务器 压力负载强度测试工具WebServer Strees Tool 8 Enterprise版

    缺点:由于不是在线方式,没有在线的分布式资源,因此不能做分布式压力测试,与真实的网络环境尚有些差距,但做为一种参考测试,完全没有问题。 网站 REST 服务器 压力负载强度等多项测试工具 德国Webserver Stress...

    Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具,用于对软件做压力测试。

    Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具,用于对软件做压力测试。 JMeter 最初被设计用于 Web 应用测试,但后来扩展到了其他测试领域,可用于测试静态和动态资源,如静态文件、Java 小服务程序、...

    VS2008,VSTS,做压力测试,性能分析

    在IT领域,压力测试和性能分析是至关重要的环节,它们能确保软件系统在高负载情况下仍然保持稳定性和高效性。Visual Studio Team System (VSTS) 2008 提供了全面的工具来执行这样的任务,它是一个集成的开发环境,...

    Web压力测试工具软件

    在Web压力测试中,这种测试通常包括模拟多个用户同时访问网站,检查服务器的处理能力、数据库的性能以及网络通信的效率。这样做可以发现潜在的瓶颈,如服务器崩溃、响应时间过长或数据丢失,从而确保在真实世界的大...

    webrtc服务器压测报告

    不同于MCU(Multipoint Control Unit)采用混合模式将所有媒体流进行混合后再转发,SFU选择单独转发每一条媒体流,这样做的好处是降低了服务器的计算压力,并且可以支持更高级的带宽适配和多编码传输,如Simulcast和...

    jmeter压力测试

    用于对软件做压力测试,它最初被设计用于Web应用测试,但后来扩展到其他测试领域。 它可以用于测试静态和动态资源,例如静态文件、Java 小服务程序、CGI 脚本、Java 对象、数据库、FTP 服务器, 等等。JMeter 可以...

Global site tag (gtag.js) - Google Analytics