并发性能测试
1 测试目的
根据Apache、Nginx并发性能测试结果分析其并发模型各自优缺点。
性能评价项包括:RPS(每秒钟处理请求数)、CPU占用率、内存占用率、最大并发数。
根据Apache、Nginx并发模型优缺点,选择合适的并发模型框架。
2 测试环境
1、硬件环境
服务器:Interl server Borad
8核CPU,2G内存,160G硬盘,
客户端:与服务器端环境相同
2、操作系统
操作系统:Red Hat EnterPrise 内核Linux 2.6.18
客户端:Red Hat EnterPrise 内核Linux 2.6.9
3、网络拓扑
服务器与客户端通过百兆网线连通一台交换机
服务器IP地址:192.168.192.201
客户端IP地址:192.168.192.200
3 测试方法
3.1 测试工具
Apache 2.2.10 自带工具bench
webbench 1.5
3.2 测试步骤
1、设备检查安装
检查系统所有设备是否完好可用,并将设备连接到主机上。
2、网络连接检查
服务器和客户端用百兆网线连接在同一交换机
3、操作系统准备
启动Red Hat Enterprise
安装鼠标驱动,配置网络
4、下载、安装、配置
参考附录
5、apache测试
运行apache
cd /usr/local/apache/bin
./apachectl -k start
测试apache服务成功启动
在windows下访问:http://192.168.192.201/index.html
出现“it works!”测试页面
运行apche bench测试程序
cd /usr/local/apache/bin
./ab -c Clients -n Requests http://192.168.192.201/index.html
运行webbench测试程序
cd /usr/local/bin
webbench -c Clients -t time http://192.168.192.200/index.html
(Clients代表用户数,Requests代表并发数)
6、Nginx测试
运行nginx
./nginx
测试nginx服务成功启动
在windows下访问:http://192.168.192.201/index.html
出现“Welcome to nginx!” 页面
为了测试结果可对比性,将apache测试页面index.html拷贝覆盖nignx测试页面
运行apche bench测试程序
cd /usr/local/apache/bin
./ab -c Clients -n Requests http://192.168.192.201/index.html
运行webbech测试程序
cd /usr/local/bin
webbench -c Clients -t time http://192.168.192.200/index.html
7、记录测试结果
记录bench测试结果:Time taken for tests(测试时间,单位:秒),Requests per second(每秒处理请求数)
记录webbench测试结果:Speed(每分钟处理请求数,为了与Apache bench一致,记录时*30转换成每秒钟处理请求数),运行时间根据操作命令-t指定,默认30秒
查看CPU占用情况命令:top
内存占用情况命令:free
4 测试方案
Nginx单线程测试
Nginx多线程测试
Apache woker模式测试
Apache prefork模式测试
5 数据汇总
测试配置:Apache配置参考7.4,Nginx配置参考7.5
原始数据参见原始数据xls
数据汇总如下:
server client RPS
Idle Free(used) Idle Free(used)
Nginx 单进程 79 102526K 82 185196K 20757
Nginx 多进程 81 395444K 85 177405K 20861
Apahce prefork 38 154380K 75 178215K 30181
Apache worker 41 81506K 81 183166K 24669
6 测试结论
7 附录
7.1 Webbench安装
步骤 操作
下载安装包 wget http://blog.s135.com/soft/linux/webbench/webbench-1.5.tar.gz
解压 tar zxvf webbench-1.5.tar.gz
编译 cd webbench-1.5
make
安装 make install
7.2 Apache安装
步骤 操作 说明
下载安装包 在http://www.apache.org下载软件包httpd-2.2.10.tar.gz 最新stable版
解压 tar xvzf httpd-2.2.10.tar.gz
编译选项 ./configure --prefix=/usr/local/apache 安装路径
--enable-module=shared 进程间共享内存
--enable-module=rewrite
--enable-threads 线程支(Worker模式有效)
--enable-shared=max
--with-mpm=worker Worker模式选择
--with-mpm=prefork Prefork模式选择
--with-mpm=event I/O复用支持
make 编译
安装 make install
7.3 Nginx安装
步骤 操作 说明
下载安装包 在http://sysoev.ru/nginx/download.html下载软件包nginx-0.7.24.tar.gz 最新stable版
解压 tar xvzf ginx-0.7.24.tar.gz
编译 ./configure --prefix=/usr/local/ 安装路径
make 编译
安装 make install
7.4 Apache配置
Apache配置命令:
cd /usr/local/apache/conf
vi http.conf
prefork模式下参数配置:
配置 Apache
prefork模式 --with-mpm=prefork
系统启动创建进程数 StartServers 128 //为跟Nginx可比
活动子进程数 ServerLimit 50000
子进程生命周期内处理连接数 MaxRequestsPerChild 0 // 0为不限制
最大子进程数 MaxClients 50000
监听端口 Listen 80
timeout Timeout 300
keepAlive KeepAlive On
Sendfile EnableSendfile on
Worker模式配置:
配置项 实现
Worker模式 --with-mpm=worker
系统启动创建进程数 StartServers 32
活动子进程数 ServerLimit 7812
最大线程数 MaxClients 500000
子进程线程数 ThreadsPerChild 64 //等于Apache允许设置的最大值
监听端口 Listen 80
timeout Timeout 300
keepAlive KeepAlive On
Sendfile EnableSendfile on
7.5 Nginx配置
Nginx配置命令 :
cd /usr/local/nginx/conf
vi nginx.conf
测试Nginx配置命令:
./nginx –t
单工作进程主要配置:
配置 Nginx
进程 worker_processes 1;
进程处理连接数 worker_connections 102400;
监听端口 server {
listen 80;
}
Sendfile sendfile on;
I/O复用方法 use epoll;
多工作进程配置:
配置 Nginx
进程 worker_processes 16;
进程处理连接数 worker_connections 102400;
监听端口 server {
listen 80;
}
Sendfile sendfile on;
I/O复用方法 use epoll;
1 测试目的
根据Apache、Nginx并发性能测试结果分析其并发模型各自优缺点。
性能评价项包括:RPS(每秒钟处理请求数)、CPU占用率、内存占用率、最大并发数。
根据Apache、Nginx并发模型优缺点,选择合适的并发模型框架。
2 测试环境
1、硬件环境
服务器:Interl server Borad
8核CPU,2G内存,160G硬盘,
客户端:与服务器端环境相同
2、操作系统
操作系统:Red Hat EnterPrise 内核Linux 2.6.18
客户端:Red Hat EnterPrise 内核Linux 2.6.9
3、网络拓扑
服务器与客户端通过百兆网线连通一台交换机
服务器IP地址:192.168.192.201
客户端IP地址:192.168.192.200
3 测试方法
3.1 测试工具
Apache 2.2.10 自带工具bench
webbench 1.5
3.2 测试步骤
1、设备检查安装
检查系统所有设备是否完好可用,并将设备连接到主机上。
2、网络连接检查
服务器和客户端用百兆网线连接在同一交换机
3、操作系统准备
启动Red Hat Enterprise
安装鼠标驱动,配置网络
4、下载、安装、配置
参考附录
5、apache测试
运行apache
cd /usr/local/apache/bin
./apachectl -k start
测试apache服务成功启动
在windows下访问:http://192.168.192.201/index.html
出现“it works!”测试页面
运行apche bench测试程序
cd /usr/local/apache/bin
./ab -c Clients -n Requests http://192.168.192.201/index.html
运行webbench测试程序
cd /usr/local/bin
webbench -c Clients -t time http://192.168.192.200/index.html
(Clients代表用户数,Requests代表并发数)
6、Nginx测试
运行nginx
./nginx
测试nginx服务成功启动
在windows下访问:http://192.168.192.201/index.html
出现“Welcome to nginx!” 页面
为了测试结果可对比性,将apache测试页面index.html拷贝覆盖nignx测试页面
运行apche bench测试程序
cd /usr/local/apache/bin
./ab -c Clients -n Requests http://192.168.192.201/index.html
运行webbech测试程序
cd /usr/local/bin
webbench -c Clients -t time http://192.168.192.200/index.html
7、记录测试结果
记录bench测试结果:Time taken for tests(测试时间,单位:秒),Requests per second(每秒处理请求数)
记录webbench测试结果:Speed(每分钟处理请求数,为了与Apache bench一致,记录时*30转换成每秒钟处理请求数),运行时间根据操作命令-t指定,默认30秒
查看CPU占用情况命令:top
内存占用情况命令:free
4 测试方案
Nginx单线程测试
Nginx多线程测试
Apache woker模式测试
Apache prefork模式测试
5 数据汇总
测试配置:Apache配置参考7.4,Nginx配置参考7.5
原始数据参见原始数据xls
数据汇总如下:
server client RPS
Idle Free(used) Idle Free(used)
Nginx 单进程 79 102526K 82 185196K 20757
Nginx 多进程 81 395444K 85 177405K 20861
Apahce prefork 38 154380K 75 178215K 30181
Apache worker 41 81506K 81 183166K 24669
6 测试结论
7 附录
7.1 Webbench安装
步骤 操作
下载安装包 wget http://blog.s135.com/soft/linux/webbench/webbench-1.5.tar.gz
解压 tar zxvf webbench-1.5.tar.gz
编译 cd webbench-1.5
make
安装 make install
7.2 Apache安装
步骤 操作 说明
下载安装包 在http://www.apache.org下载软件包httpd-2.2.10.tar.gz 最新stable版
解压 tar xvzf httpd-2.2.10.tar.gz
编译选项 ./configure --prefix=/usr/local/apache 安装路径
--enable-module=shared 进程间共享内存
--enable-module=rewrite
--enable-threads 线程支(Worker模式有效)
--enable-shared=max
--with-mpm=worker Worker模式选择
--with-mpm=prefork Prefork模式选择
--with-mpm=event I/O复用支持
make 编译
安装 make install
7.3 Nginx安装
步骤 操作 说明
下载安装包 在http://sysoev.ru/nginx/download.html下载软件包nginx-0.7.24.tar.gz 最新stable版
解压 tar xvzf ginx-0.7.24.tar.gz
编译 ./configure --prefix=/usr/local/ 安装路径
make 编译
安装 make install
7.4 Apache配置
Apache配置命令:
cd /usr/local/apache/conf
vi http.conf
prefork模式下参数配置:
配置 Apache
prefork模式 --with-mpm=prefork
系统启动创建进程数 StartServers 128 //为跟Nginx可比
活动子进程数 ServerLimit 50000
子进程生命周期内处理连接数 MaxRequestsPerChild 0 // 0为不限制
最大子进程数 MaxClients 50000
监听端口 Listen 80
timeout Timeout 300
keepAlive KeepAlive On
Sendfile EnableSendfile on
Worker模式配置:
配置项 实现
Worker模式 --with-mpm=worker
系统启动创建进程数 StartServers 32
活动子进程数 ServerLimit 7812
最大线程数 MaxClients 500000
子进程线程数 ThreadsPerChild 64 //等于Apache允许设置的最大值
监听端口 Listen 80
timeout Timeout 300
keepAlive KeepAlive On
Sendfile EnableSendfile on
7.5 Nginx配置
Nginx配置命令 :
cd /usr/local/nginx/conf
vi nginx.conf
测试Nginx配置命令:
./nginx –t
单工作进程主要配置:
配置 Nginx
进程 worker_processes 1;
进程处理连接数 worker_connections 102400;
监听端口 server {
listen 80;
}
Sendfile sendfile on;
I/O复用方法 use epoll;
多工作进程配置:
配置 Nginx
进程 worker_processes 16;
进程处理连接数 worker_connections 102400;
监听端口 server {
listen 80;
}
Sendfile sendfile on;
I/O复用方法 use epoll;