在以前的博客中提到的一个服务端,在以前压力测试的过程中,发现单核CPU最多能达到1000TPS

还以为是服务端性能不够好,所以一直想着怎么去优化它。

但优化的思路明显不多,所以就考虑换一种压力测试的方法,事实证明这个想法是对的。

以前的压力测试方法 :

for((i=;i<$;i++));do

       for((j=;j<$;j++));do
cmd="./client $1 $2 4 $a $a $a $a"
echo `time $cmd` done& done

思路是用多进程来实现并发,代码如上所示;

现在的压力测试方法:

//客户端程序    

/******* 客户端程序 client.c ************/
#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <string.h>
#include <netdb.h>
#include <netinet/in.h>
#include <errno.h>
#include <arpa/inet.h>
#include <fcntl.h>
#include <unistd.h>
#include <sys/epoll.h> static struct sockaddr_in server_addr;
static int epoll_fd;
static int currency,total_req,total_read;
static struct epoll_event* events; int setnonblock(int fd)
{
int flags;
flags = fcntl(fd, F_GETFL);
flags |= O_NONBLOCK;
fcntl(fd, F_SETFL, flags);
} void new_conn()
{
if(--total_req < )return;
int sockfd;
/* 客户程序开始建立 sockfd描述符 */
if((sockfd=socket(AF_INET,SOCK_STREAM,))==-)
{
fprintf(stderr,"Socket Error:%s\a\n",strerror(errno));
return ;
}
setnonblock(sockfd); //让epoll接管
struct epoll_event event;
event.data.fd=sockfd;
event.events = EPOLLOUT|EPOLLIN;
epoll_ctl(epoll_fd,EPOLL_CTL_ADD, sockfd,&event); /* 客户程序发起连接请求 */
if(connect(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-)
{
if(errno == EINPROGRESS)
return;
fprintf(stderr,"Connect Error:%s\a\n",strerror(errno));
return;
} }
int main(int argc, char *argv[])
{
struct hostent *host;
if((host=gethostbyname(argv[]))==NULL)
{
fprintf(stderr,"Gethostname error\n");
exit();
} int portnumber;
if((portnumber=atoi(argv[]))<)
{
fprintf(stderr,"Usage:%s hostname portnumber\a\n",argv[]);
exit();
} /* 客户程序填充服务端的资料 */
bzero(&server_addr,sizeof(server_addr));
server_addr.sin_family=AF_INET;
server_addr.sin_port=htons(portnumber);
server_addr.sin_addr=*((struct in_addr *)host->h_addr); //并发数和总的请求数
currency = atoi(argv[]);
total_req = total_read = currency * atoi(argv[]); if((epoll_fd=epoll_create())==-)
{
fprintf(stderr,"epoll create Error:%s\a\n",strerror(errno));
exit();
} events = calloc(,sizeof(struct epoll_event)); //初始化并发数个连接
int i;
for(i=;i<currency;i++)new_conn(); while()
{
fprintf(stderr,"while\n");
int n,j;
n = epoll_wait(epoll_fd, events, , -);
for(j=;j<n;j++)
{
if(events[j].events & EPOLLOUT)
{
fprintf(stderr, "can write\n",n);
int fd = events[j].data.fd;
int optval;
socklen_t optlen = sizeof(optval);
if(getsockopt(fd,SOL_SOCKET,SO_ERROR,&optval, &optlen) == -)
{
fprintf(stderr, "getsockopt error\n",n);
} else if(optval != ) {
fprintf(stderr, "connect error\n",n);
continue;
};
struct epoll_event event;
event.data.fd=fd;
event.events = EPOLLIN;
epoll_ctl(epoll_fd,EPOLL_CTL_MOD, fd,&event); char buffer2[];
memset(buffer2,,);
int type,score,time;
unsigned long oid;
type= htonl(atoi(argv[]));
oid= htonl(atol(argv[]));
score= htonl(atoi(argv[]));
char*pass="220106aa";
char*loc = buffer2;
memcpy((void*)loc,(void*)(pass),);
loc+=;
memcpy((void*)loc,(void*)(&type),);
loc+=;
memcpy((void*)loc,(void*)(&oid),);
loc+=;
memcpy((void*)loc,(void*)(&score),);
write(fd, buffer2, );
/* 连接成功了 */
}
else if(events[j].events & EPOLLIN)
{
fprintf(stderr, "can read\n",n);
int fd = events[j].data.fd;
char buf[];
int n=read(fd,buf,);
close(fd);
new_conn();
if(n==-)
{
fprintf(stderr,"read Error:%s\a\n",strerror(errno));
continue;
}
buf[n]=;
fprintf(stderr, "return %s\n",buf);
fprintf(stderr, "total_read %d\n",total_read);
if (--total_read <= )return;
}
}
}
}

思路就是用单进程来测试,用EPOOL来实现并发
代码也可下载:
百度网盘:http://pan.baidu.com/s/1vdQqB
github : https://github.com/hxdoit/real_time_rank/blob/master/server1-1.0/epoll.c

性能对比:
环境:单核CPU,两台机器,一台服务端,一台客户端
多进程:690TPS
EPOLL:6435TPS
性能提高了十倍!

分析:
在单个机器上,使用多进程,资源消耗很大,不可能达到太大的并发
而使用EPOLL,单进程同时监听多个socket,可以达到较高并发

用EPOLL进行压力测试的更多相关文章

  1. 对apache和memcache进行压力测试

    工作中经常使用的软件之二:apache和memcache 以前经常听说memcache的TPS能达到几万,但一直也不知道apache的性能到底如何,所以在闲暇之余,就自己做了一下压力测试. 环境:两台 ...

  2. 一次压力测试Bug排查-epoll使用避坑指南

    Bug复现 使用Webbench对服务器进行压力测试,创建1000个客户端,并发访问服务器10s,正常情况下有接近8万个HTTP请求访问服务器. 结果显示仅有7个请求被成功处理,0个请求处理失败,服务 ...

  3. DNS压力测试工具dnsperf简介

    dnsperf是我最近写的一个开源的DNS压力测试工具,用户可以用它来对DNS服务器或者Local DNS做压力测试.dnsperf目前的实现是单进程模式,通过epoll非阻塞地处理网络事件. dns ...

  4. 压力测试 php-fpm 优化

    webbench最多可以模拟3万个并发连接去测试网站的负载能力,个人感觉要比Apache自带的ab压力测试工具好,安装使用也特别方便. 1.适用系统:Linux 2.编译安装:引用wget http: ...

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

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

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

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

  7. nginx优化php-fpm优化 压力测试达到每分150万访问量webbench网站压力

    webbench最多可以模拟3万个并发连接去测试网站的负载能力,个人感觉要比Apache自带的ab压力测试工具好,安装使用也特别方便. 1.适用系统:Linux 2.编译安装:引用wget http: ...

  8. 从零开始一个http服务器(六)-多路复用和压力测试

    从零开始一个http服务器(六)-多路复用和压力测试 代码地址 : https://github.com/flamedancer/cserver git checkout step6 运行: make ...

  9. JMeter工具接口性能压力测试分析与优化

    最近公司做的项目,要求对相关接口做性能压力测试,在这里记录一下分析解决过程. 压力测试过程中,如果因为资源使用瓶颈等问题引发最直接性能问题是业务交易响应时间偏大,TPS逐渐降低等.而问题定位分析通常情 ...

随机推荐

  1. Android:Style和Theme

    在Web开发中,Html负责内容,CSS负责表现.同样,在Android开发中,可以使用Theme.Style+UI组件的方式实现内容和形式的分离. Style是针对窗体元素级别的,改变指定控件或者L ...

  2. VC编程技巧:IE控件的高级用法

    一.如何显示内存中的 HTML 网页 二.屏蔽 IE 控件的上下文菜单 三.扩展 HTML 脚本中的 external 对象 四.显示 HTML 样式的对话窗 五.执行 HTML 脚本 http:// ...

  3. mysql rr 查询出现的事务情况

    select * from INFORMATION_SCHEMA.INNODB_TRX\G The INNODB_TRX table contains information about every ...

  4. JPA简单知识

    ,JPA(Java Persistence API):通过注解或XML描述对象--关系表的映射关系,并将运行期的实体对象持久化到数据库中. JPA是一套规范,不是某个ORM产品,它主要包括以下3方面的 ...

  5. jQuery修改操作css属性实现方法

    在jquery中我们要动态的修改css属性我们只要使用css()方法就可以实现了,下面我来给各位同学详细介绍介绍. css()方法在使用上具有多样性,我们先来了解css()方法基本知识. css() ...

  6. Explain 结果解读与实践

    Explain 结果解读与实践 基于 MySQL 5.0.67 ,存储引擎 MyISAM . 注:单独一行的"%%"及"`"表示分隔内容,就象分开“第一章”“第 ...

  7. SourceGrid zt

    SourceGrid介绍和使用及实例举例 先上图,来一个简单演示: SourceGrid就是一个用于数据显示的表格控件,这个控件比c#自带的 DataGridView要强大很多,先不说他的原理,只说他 ...

  8. C# 检测机器是否有声卡设备

    有时候我们的程序需要进行音频的播放,则我们首先需要判断机器是否有声卡能够进行音频的播放.在网上找了一下没有发现太多关于如何检机器是否有声卡的例子.我在看了一些文档后自己写了一个小测试程序,如果机器装有 ...

  9. FL2440移植u-boot2011.09

    u-boot version:2011.09-rc1 /home/lucas/u-boot-2011.09-rc1 OS:debian 7.1 cross-compilation chain:arm- ...

  10. Linux下复制粘贴快捷键

    1. 在控制台下:            1.1.鼠标选中要复制的文本,按鼠标中键,即为复制                              或者              1.2.复制命令 ...