设为首页 收藏本站
查看: 837|回复: 0

[经验分享] 网站服务器压力Web性能测试:Apache Bench,Webbench,http_load安装使用

[复制链接]

尚未签到

发表于 2018-11-21 12:40:01 | 显示全部楼层 |阅读模式
  一个网站或者博客到底能够承受多大的用户访问量经常是我们在用VPS或者独立服务器搭建网站了最关心的问题,还有不少人喜欢对LNMP或者LAMP进行一些优化以便提高Web性能,而优化后到底有多大的效果,就需要我们对网站进行服务器压力测试了。
  目前来说Webbench,Apache Bench,http_load是三款比较流行的网站服务器压力Web性能测试工具,安装和使用都非常简单,只要有一台VPS主机或者直接用本地电脑就可以开始测试,由于受网络等各种因素的影响,测试结果不一定很准确,但可以当作参考。
  Apache Bench又叫做AB,是Apache 附带的一个小工具,专门用于 HTTP Server 的benchmark testing,ab命令会创建很多的并发访问线程,模拟多个访问者同时对某一URL进行访问,可用来测试Apache的负载压力,也可以测试nginx、lighthttp、IIS等其它Web服务器的压力。
  Webbench是由Lionbridge公司开发出来的一个网站压力测试工具,可用于测试ASP,PHP,JAVA,CGI等服务器压力,也可用于SSL的安全网站的负载能力进行测试,最多可以模拟3万个并发连接去测试网站的负载能力,Webbench操作简单,一行命令就可以显示出服务器压力。
  http_load这是国外一个博主开发的基于linux平台的性能测试工具,主要是以并行复用的方式运行,可以用来测试web服务器的吞吐量与负载,测试结果一目了然。Apache Bench,Webbench,http_load这三款网站服务器压力测试工具还要根据测试者的主机性能来决定参数,防止把测试主机给搞成死机了。
  还没有自己的Web服务器的朋友,可以用以下几个软件在本地或者远程主机上搭建一个网站服务器:

  •   1、Web软件:十款免费Web服务器套件-轻松搭建Apache,PHP,PhpMyAdmin,MySQL
  •   2、安卓手机变身服务器:Android手机用KSWEB搭建Web服务器成功安装WordPress
  •   3、PHP反代方法:7ghost基于PHP的网站反向绑定域名程序无需.htaccess的URL重写
  服务器压力Web性能测试:Apache Bench,Webbench,http_load安装使用
  一、Apache Bench:Apache自带服务器压力测试工具
  1、要使用Apache Bench工具,只要VPS主机已经有了Apache就行了,如果安装Apache,可直接运行命令:yum install httpd。
  2、Apache Bench工具用法命令:ab -n 100 -c 50 http://www.qq.com/,“-n”表示:每次请求数,默认不能超过1024个,“-c”表示:1个请求的并发连接数,默认最大不能超过50000。注意C
  3、上面的命令就是模拟50个并发连接每次以100个请求数来测试腾讯网站的Web性能。测试结果及相关的数据说明请看下图:(点击放大)
DSC0000.gif

  4、为了避免因为网络原因而导致服务器压力测试结果不准确,一般可以用ab -n 100 -c 50 http://127.0.0.1/index.php 来测试自己服务器Web性能。
  5、被测试的网站服务器可以在日志中查看到Apache Bench工具访问的记录。(点击放大)
DSC0001.png

  二、Webbench:最多模拟3万个并发连接数测试压力
  1、Webbench最多可以模拟3万个并发连接数来测试服务器压力,可以设置压力测试时间和测试请求的成功率。安装Webbench命令:
wget http://home.tiscali.cz/~cz210552/distfiles/webbench-1.5.tar.gz  
tar zxvf webbench-1.5.tar.gz
  
cd webbench-1.5
  
make && make install
  2、如果有错误,执行安装:yum install ctags和yum install gcc,如果有出现没有文件路径错误,执行:mkdir -m 644 -p /usr/local/man/man1
DSC0002.gif

  3、Webbench测试命令是:webbench -c 100 -t 10 http://www.qq.com/index.php,-c是并发数 -t是运行测试时间,即10秒钟内中以每次100个请求进行测试。
  4、这是运行Webbench测试结果,Speed显示的是每分钟响应请求数和每秒钟传输数据量,Requests显示的是成功请求数和失败请求数。
DSC0003.gif

  5、查看服务器日志,可以看到有Webbench访问的记录。
DSC0004.gif

  6、为准确得到服务器的承受压力,测试时并发数可逐渐加大,如并发100时观察一下网站负载是多少、打开页面是否流畅,当网站打开缓慢时并发是多少、网站打不开时并发又是多少。
  三、http_load:测试web服务器的吞吐量与负载
  1、http_load是国外一个博主写的一个基于Linux的性能测工具,小巧轻便,解压缩后不到100k,下载安装方法:
wget http://acme.com/software/http_load/http_load-12mar2006.tar.gz  
tar xzvf http_load-12mar2006.tar.gz
  
cd http_load-12mar2006
  
mkdir /usr/local/man
  
make && make install
  2、如果遇到错误,可以执行安装:yum -y install gcc gcc-c++
DSC0005.gif

  3、测试之前先执行进入目录:cd http_load-12mar2006,然后再执行:vi url,输入你想要测试的域名网址,保存退出。
DSC0006.gif

  4、http_load测试的命令格式是:./http_load -p 100 -s 10 url ,-p表示并发进程数,-s表示持续时间,此命令表示在10秒钟内以每次100个并发进程发起请求。
  5、这是运行http_load后的结果演示:
DSC0007.gif

  6、http_load有关参数解释说明如下:
[root@None http_load-12mar2006]# ./http_load -p 100 -s 10 url  
495 fetches, 100 max parallel, 2.24393e+07 bytes, in 10.0022 seconds
  
一共请求连接495次,最大并发线程100个,持续10.0022秒,总传输速率为 2.24393e+07 bytes
  

  
45332 mean bytes/connection
  
每次请求连接平均数据量
  

  
49.4891 fetches/sec, 2.24344e+06 bytes/sec
  
每秒的响应请求连接数,每秒传输的数据量
  

  
msecs/connect: 112.466 mean, 157.051 max, 103.031 min
  
每次连接平均响应时间,最大时间,最小时间
  

  
msecs/first-response: 1053.73 mean, 2466.83 max, 179.647 min
  
每次连接平均返回时间,最大,最小。
  

  
HTTP response codes:
  
  code 200 -- 495
  
HTTP返回码:200 ,一共495次。
  7、测试结果中,主要参考fetches/sec、msecs/connect数值,即服务器每秒能够响应的查询次数的数值来衡量性能。
  四、服务器压力Web性能测试小结
  1、Apache Bench,Webbench,http_load对网站压力Web性能进行测试时,为了得到更加客观和准确的数值,应该从远程访问、局域网访问和本地等多个方面进行全方位的测试。一般用127.0.0.1进行本机测试。
  2、当然,单纯数值判断并不准确,还要参考CPU、内存的等消耗综合考虑。这三款工具大家自己使用也须谨慎,防止一次上太多的负载,造成目标服务器直接因内存耗光死机,而不得不硬重启,得不偿失。
  一、http_load
  程序非常小,解压后也不到100K
  http_load以并行复用的方式运行,用以测试web服务器的吞吐量与负载。但是它不同于大多数压力测试工
  具,它可以以一个单一的进程运行,一般不会把客户机搞死。还可以测试HTTPS类的网站请求。
  下载地址:http://soft.vpser.net/test/http_load/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 urls.txt也是可以的。我们把参数给大家简单说明一下。
  -parallel 简写-p :含义是并发的用户进程数。
  -fetches 简写-f :含义是总计的访问次数
  -rate    简写-p :含义是每秒的访问频率
  -seconds简写-s :含义是总计的访问时间
  准备URL文件:urllist.txt,文件格式是每行一个URL,URL最好超过50-100个测试效果比较好.文件格式
  如下:
  http://www.vpser.net/uncategorized/choose-vps.html
  http://www.vpser.net/vps-cp/hypervm-tutorial.html
  http://www.vpser.net/coupons/diavps-april-coupons.html
  http://www.vpser.net/security/vps-backup-web-mysql.html
  例如:
  http_load -p 30 -s 60  urllist.txt
  参数了解了,我们来看运行一条命令来看看它的返回结果
  命令:% ./http_load -rate 5 -seconds 10 urls说明执行了一个持续时间10秒的测试,每秒的频率为5。
  49 fetches, 2 max parallel, 289884 bytes, in 10.0148 seconds5916 mean bytes/connection4.89274
  fetches/sec, 28945.5 bytes/secmsecs/connect: 28.8932 mean, 44.243 max, 24.488 minmsecs/first
  -response: 63.5362 mean, 81.624 max, 57.803 minHTTP response codes: code 200 -- 49
  结果分析:
  1.49 fetches, 2 max parallel, 289884 bytes, in 10.0148 seconds
  说明在上面的测试中运行了49个请求,最大的并发进程数是2,总计传输的数据是289884bytes,运行的时间是10.0148秒
  2.5916 mean bytes/connection说明每一连接平均传输的数据量289884/49=5916
  3.4.89274 fetches/sec, 28945.5 bytes/sec
  说明每秒的响应请求为4.89274,每秒传递的数据为28945.5 bytes/sec
  4.msecs/connect: 28.8932 mean, 44.243 max, 24.488 min说明每连接的平均响应时间是28.8932 msecs
  ,最大的响应时间44.243 msecs,最小的响应时间24.488 msecs
  5.msecs/first-response: 63.5362 mean, 81.624 max, 57.803 min
  6、HTTP response codes: code 200 -- 49     说明打开响应页面的类型,如果403的类型过多,那可能
  要注意是否系统遇到了瓶颈。
  特殊说明:
  测试结果中主要的指标是 fetches/sec、msecs/connect 这个选项,即服务器每秒能够响应的查询次数,
  用这个指标来衡量性能。似乎比 apache的ab准确率要高一些,也更有说服力一些。
  Qpt-每秒响应用户数和response time,每连接响应用户时间。
  测试的结果主要也是看这两个值。当然仅有这两个指标并不能完成对性能的分析,我们还需要对服务器的
  cpu、men进行分析,才能得出结论
  二、webbench
  webbench是Linux下的一个网站压力测试工具,最多可以模拟3万个并发连接去测试网站的负载能力。下载
  地址可以到google搜,我这里给出一个
  下载地址:http://soft.vpser.net/test/webbench/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 5000 -t 120 http://www.vpser.net/
  三、ab
  ab是apache自带的一款功能强大的测试工具
  安装了apache一般就自带了,
  用法可以查看它的说明
  $ ./ab
  ./ab: wrong number of arguments
  Usage: ./ab [options] [http://]hostname[:port]/path
  Options are:
  -n requests Number of requests to perform
  -c concurrency Number of multiple requests to make
  -t timelimit Seconds to max. wait for responses
  -p postfile File containing data to POST
  -T content-type Content-type header for POSTing
  -v verbosity How much troubleshooting info to print
  -w Print out results in HTML tables
  -i Use HEAD instead of GET
  -x attributes String to insert as table attributes
  -y attributes String to insert as tr attributes
  -z attributes String to insert as td or th attributes
  -C attribute Add cookie, eg. 'Apache=1234. (repeatable)
  -H attribute Add Arbitrary header line, eg. 'Accept-Encoding: gzip'
  Inserted after all normal header lines. (repeatable)
  -A attribute Add Basic WWW Authentication, the attributes
  are a colon separated username and password.
  -P attribute Add Basic Proxy Authentication, the attributes
  are a colon separated username and password.
  -X proxy:port Proxyserver and port number to use
  -V Print version number and exit
  -k Use HTTP KeepAlive feature
  -d Do not show percentiles served table.
  -S Do not show confidence estimators and warnings.
  -g filename Output collected data to gnuplot format file.
  -e filename Output CSV file with percentages served
  -h Display usage information (this message)
  参数众多,一般我们用到的是-n 和-c
  例如:
  ./ab -c 1000 -n 100 http://www.vpser.net/index.php
  这个表示同时处理1000个请求并运行100次index.php文件.
  四、Siege
  一款开源的压力测试工具,可以根据配置对一个WEB站点进行多用户的并发访问,记录每个用户所有请求过程的相应时间,并在一定数量的并发访问下重复进行。
  官方:http://www.joedog.org/
  Siege下载:http://soft.vpser.net/test/siege/siege-2.67.tar.gz
  解压:
  # tar -zxf siege-2.67.tar.gz
  进入解压目录:
  # cd siege-2.67/
  安装:
  #./configure ; make
  #make install
  使用
  siege -c 200 -r 10 -f example.url
  -c是并发量,-r是重复次数。 url文件就是一个文本,每行都是一个url,它会从里面随机访问的。
  example.url内容:
  http://www.licess.cn
  http://www.vpser.net
  http://soft.vpser.net
  结果说明
  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 //每次传输所花最短时间



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-637799-1-1.html 上篇帖子: 用Apache Kafka构建流数据平台 下篇帖子: apache启动报错(98)Address already in use: make_sock: could not bind to address [::]:
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表