#-----------http_load讲解------------------------------------#
   Web服务器压力测试工具常见的有http_load、webbench、ab和Siege,
我今天主要跟大家分享一下,我在工作中对http_load使用的总结。

一、下载http_load
    下载地址:http://www.acme.com/software/http_load/http_load-12mar2006.tar.gz
二、安装http_load
    tar zxvf http_load-12mar2006.tar.gz
    cd http_load-12mar2006
    make && make install
三、使用http_load
    命令格式:http_load  -p 并发访问进程数  -s 访问时间  需要访问的URL文件
    比如:http_load -p 5 -s 60   url.tx
    或者  http_load -parallel 5 -seconds 60 url.txt
四、参数讲解
    -parallel 简写-p :含义是并发的用户进程数。
    -fetches 简写-f :含义是总计的访问次数
    -rate    简写-p :含义是每秒的访问频率
    -seconds简写-s :含义是总计的访问时间
五、URL文件格式
    URL文件:url.txt,文件格式是每行一个URL,URL最好超过50-100个测试效果比较好.文件格式
    如下:
    http.www.bdkyr.com/5k.html
    http.www.bdkyr.com/10k.html
    http.www.bdkyr.com/15k.html
    http.www.bdkyr.com/20k.html
六、使用范例
    例如:
   [root@node2 http_load]# ./http_load -p 2 -s 10  url.txt
   49 fetches, 2 max parallel, 289884 bytes, in 10.0148 seconds 
   5916 mean bytes/connection
   4.89274 fetches/sec, 28945.5 bytes/sec
   msecs/connect 28.8932 mean, 44.243 max, 24.488 min
   msecs/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
   说明每一连接平均传输的数据量28988449=5916

3.4.89274 fetches/sec, 28945.5 bytes/sec
   说明每秒的响应请求为4.89274,每秒传递的数据为28945.5 bytessec

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的类型过多,那可能
   要注意是否系统遇到了瓶颈。

七、特殊说明:
       测试结果中主要的指标是 fetchessec、msecs/connect 这个选项,即服
   务器每秒能够响应的查询次数,用这个指标来衡量性能。似乎比 apache的ab准
   确率要高一些,也更有说服力一些。

Qpt-每秒响应用户数和response time,每连接响应用户时间。
   测试的结果主要也是看这两个值。当然仅有这两个指标并不能完成对性能的分析,
   我们还需要对服务器的cpu、men进行分析,才能得出结论

httpload的用法

官方网站http://www.acme.com/software/http_load/
一、安装
$ wget http://acme.com/software/http_load/http_load-12mar2006.tar.gz
$ tar zxvf http_load-12mar2006.tar.gz
$ cd http_load-12mar2006/

$ make

$ sudo make install

安装到/usr/local/bin

可以通过man http_load查看使用说明(前提将http_load.1文件拷贝到man得查找路径中)

1错误信息:byte count wrong

http_load在处理时会去关注每次访问同一个URL返回结果(即字节数)是否一致,若不一致就会抛出byte count wrong

所以动态页面可以忽略这个错误信息。

或者可以对代码做修改http_load.c

【原来的】
“stderr, "%s: byte count wrong\n", urls[url_num].url_str );”
【修改的】
“stderr, "%s: byte count wrong: first=%ld,cur=%ld\n", urls[url_num].url_str,urls[url_num].bytes,connections[cnum].bytes );”

报错:too many open files
系统限制的open files太小,ulimit -n 修改open files值即可;

无法发送大请求 (请求长度>600个字符)
默认接受请求的buf大小 http_load.c

912 static void
913 handle_connect( int cnum, struct timeval* nowP, int double_check )
914 {
915 int url_num;
916 char buf[600]; //根据需要修改,如:char buf[4096]
917 int bytes, r;

,表示关闭;
net.ipv4.tcp_timestamps=1 开启对于TCP时间戳的支持,若该项设置为0,则下面一项设置不起作用
net.ipv4.tcp_tw_recycle=1 表示开启TCP连接中TIME-WAIT sockets的快速回收

客户端频繁的连服务器,由于每次连接都在很短的时间内结束,导致很多的TIME_WAIT,以至于用光了可用的端 口号,所以新的连接没办法绑定端口,即“Cannot assign requested address”。是客户端的问题不是服务器端的问题。通过netstat,的确看到很多TIME_WAIT状态的连接。
从网上找了解决办法:
执行命令修改如下2个内核参数

sysctl -w net.ipv4.tcp_timestamps=1  开启对于TCP时间戳的支持,若该项设置为0,则下面一项设置不起作用

sysctl -w net.ipv4.tcp_tw_recycle=1  表示开启TCP连接中TIME-WAIT sockets的快速回收

使用方式:

http_load -parallel 100 -fetches 10000

http_load -parallel 100 -seconds 3600

小时

http_load -rate 100 -fetches 10000

个请求频率,请求10000次

http_load -rate 100 -seconds 3600

个请求频率执行1小时

测试报告

209 fetches, 10 max parallel, 6.9004e+06 bytes, in 30 seconds

33016.3 mean bytes/connection

6.96667 fetches/sec, 230013 bytes/sec

msecs/connect: 31.8767 mean, 34.121 max, 31.304 min

msecs/first-response: 274.644 mean, 3228.69 max, 127.399 min

208 bad byte counts

HTTP response codes:

code 200 -- 209

nginx的压力测试的更多相关文章

  1. Nginx防压力测试

    一.ab压力测试方式为: $ab -n 1000 -c 100 http://www.abc.com:80/ 二.直接简单的方法限制同一个IP的并发最大为10:(以宝塔管理工具为例) 1.打开Ngin ...

  2. Nginx ab压力测试

    20-ab压力测试及nginx性能统计模块 优化的启发,打开的文件太多 Nginx 错误日志显示,打开文件数太多 系统层面 more /proc/sys/net/core/somaxconn 单个Ng ...

  3. linux 下 安装nginx及压力测试

    linux 编译安装nginx,配置自启动脚本 下载nginx: wget http://nginx.org/download/nginx-1.8.0.tar.gz下载openssl : wget h ...

  4. 使用ab对nginx进行压力测试

    nginx以高并发,省内存著称. 相信大多数安装nginx的同学都想知道自己的nginx性能如何. 我想跟大家分享下我使用ab工具的压力测试方法和结果, ab是针对apache的性能测试工具,可以只安 ...

  5. Nginx - webbench压力测试

    1. 下载,安装,进目录. 2. 执行:webbench -t 10 -c 1000 http://192.168.1.44/ (我开的nginx,默认端口80,直接处理了) 结果分析: Webben ...

  6. Nginx压力测试工具之WebBench

    Nginx压力测试工具之WebBench   在Apache中有自带的ab命令可以测试服务的压力,而nginx没有自带的命令,必须要采用第三方软件来测试,今天就简单介绍一下webbench对nginx ...

  7. 记录一次自己对nginx+fastcgi(fpm)+mysql压力测试结果

    nginx + fastcgi(fpm) 压力测试: CentOS release 5.9 16核12G内存 静态页面: 并发1000,压测200秒,测试结果: 系统最大负载5.47 成功响应: 25 ...

  8. Nginx配置性能优化与压力测试webbench【转】

    这一篇我们来说Nginx配置性能优化与压力测试webbench. 基本的 (优化过的)配置 我们将修改的唯一文件是nginx.conf,其中包含Nginx不同模块的所有设置.你应该能够在服务器的/et ...

  9. linux nginx常见问题及优化,压力测试,tomcat服务器优化

    nginx常见问题 nginx优化全局配置优化[root@web2 nginx]# vim conf/nginx.confuser nobody;worker_processes 1;(与cpu核心数 ...

随机推荐

  1. 经验分享:使用 Restyle.js 简化 CSS 预处理

    Andrea Giammarchi的restyle.js是一个新的,基于JavaScript的CSS预处理器,能够运行在服务端(通过Node.js)或者浏览器中.它宣称自己是“一种简化的CSS方法”, ...

  2. [转]CentOS更改yum源与更新系统

    [1] 首先备份/etc/yum.repos.d/CentOS-Base.repo mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/Cent ...

  3. linux tar 增量备份命令

    tar --newer-mtime "2013-09-17 00:00:00"   -zcvf /var/www/good.tar.gz    spider/

  4. 在 Linux 中怎样将 MySQL 迁移到 MariaDB 上

    自从甲骨文收购 MySQL 后,由于甲骨文对 MySQL 的开发和维护更多倾向于闭门的立场,很多 MySQL 的开发者和用户放弃了 MySQL.在社区驱动下,促使更多人移到 MySQL 的另一个叫 M ...

  5. java版复利计算

    这是我修改为java的初定界面,还有很多细节问题还没有解决,希望老师可以给我多点的点评,接下来继续努力,我会把每一次的进步发上来,不断的去锻炼. 1.我所用的开发工具是ecipse 2.所有的语言为j ...

  6. static详解

    static关键字用来修饰属性.方法,称这些属性.方法为静态属性.静态方法. static关键字声明一个属性或方法是和类相关的,而不是和类的某个特定的实例相关,因此,这类属性或方法也称为“类属性”或“ ...

  7. flash as3 socket安全服务网关(socket policy file server)

    关键字: SecurityErrorEvent socket as3 flash有着自己的一套安全处理模式,在socket方面,我这样的菜鸟无法理解他的好处:一句话,不怀好意的人如果想用flash写一 ...

  8. hdu 4622 Reincarnation

    http://acm.hdu.edu.cn/showproblem.php?pid=4622 用字典树把每一个字符串对应成一个整数 相同的字符串对应到相同的整数上 把所用的串对应的整数放在一个数组里 ...

  9. 二模 (8) day1

    第一题: 题目大意: 梦幻城市每年为全市高中生兴办一次运动会.为促使各校同学之间的交流,采用特别的分队方式:每一个学校的同学,必须被均匀分散到各队,使得每一队中该校的人数皆相同.为增加比赛的竞争性,希 ...

  10. Section 1.4 Packing Rectangles

    本来是USACO Training的1.4.1的,但是介于今早过了食物链想起了这道题实在是太怨念了,翻出自己写的AC程序居然有5KB!! 思路很简单,枚举,而且就图中的六种情况.但是第六种变化状况太多 ...