各位大侠,我的epoll为什么会非常的慢

walkany 2010-12-21 09:29:42
这个epoll server跑起来很慢,为什么?哪位大侠可以帮忙看看啊?




void setnonblocking(int sock)
{
int opts;
opts=fcntl(sock,F_GETFL);
if(opts<0)
{
perror("fcntl(sock,GETFL)");
exit(1);
}
opts = opts|O_NONBLOCK;
if(fcntl(sock,F_SETFL,opts)<0)
{
perror("fcntl(sock,SETFL,opts)");
exit(1);
}
}



int main()
{
int i, maxi, listenfd, connfd, sockfd,epfd,nfds;
ssize_t n;
int coun;


char line[MAXLINE+2];
socklen_t clilen;
//声明epoll_event结构体的变量,ev用于注册事件,数组用于回传要处理的事件
struct epoll_event ev,events[80];
//生成用于处理accept的epoll专用的文件描述符
epfd=epoll_create(2560);
struct sockaddr_in clientaddr;
struct sockaddr_in serveraddr;

listenfd = socket(AF_INET, SOCK_STREAM, 0);
//把socket设置为非阻塞方式
setnonblocking(listenfd);
//设置与要处理的事件相关的文件描述符
ev.data.fd=listenfd;
//设置要处理的事件类型
ev.events=EPOLLIN|EPOLLET;
//ev.events=EPOLLIN;
//注册epoll事件
epoll_ctl(epfd,EPOLL_CTL_ADD,listenfd,&ev);
bzero(&serveraddr, sizeof(serveraddr));
serveraddr.sin_family = AF_INET;
char *local_addr="10.163.96.186";
inet_aton(local_addr,&(serveraddr.sin_addr));//htons(SERV_PORT);
serveraddr.sin_port=htons(SERV_PORT);
bind(listenfd,(struct sockaddr *)&serveraddr, sizeof(serveraddr));
listen(listenfd, LISTENQ);
maxi = 0;
coun = 0;

for ( ; ; ) {
//等待epoll事件的发生
nfds=epoll_wait(epfd,events,2560,0);
//处理所发生的所有事件
for(i=0;i<nfds;++i)
{
if(events[i].data.fd==listenfd)
{
connfd = accept(listenfd,(struct sockaddr *)&clientaddr, &clilen);
if(connfd<0){
perror("connfd<0");
exit(1);
}
//setnonblocking(connfd);
char *str = inet_ntoa(clientaddr.sin_addr);
printf(" \n accapt a connection from %s " ,str );
//设置用于读操作的文件描述符
ev.data.fd=connfd;
//设置用于注测的读操作事件
ev.events=EPOLLIN|EPOLLET;
//ev.events=EPOLLIN;
//注册ev
epoll_ctl(epfd,EPOLL_CTL_ADD,connfd,&ev);
}
else if(events[i].events&EPOLLIN)
{
// printf( "\n EPOLLIN ");
if ( (sockfd = events[i].data.fd) < 0)
continue;
if ( (n = read(sockfd, line, MAXLINE)) < 0) {
if (errno == ECONNRESET) {
close(sockfd);
events[i].data.fd = -1;
} else
printf("\n readline error");
} else if (n == 0) {

close(sockfd);
events[i].data.fd = -1;
}
line[n] = '\0';
//printf( "\n %s ",line );
//设置用于写操作的文件描述符
ev.data.fd=sockfd;
//设置用于注测的写操作事件
ev.events=EPOLLOUT|EPOLLET;
//修改sockfd上要处理的事件为EPOLLOUT
epoll_ctl(epfd,EPOLL_CTL_MOD,sockfd,&ev);
}
else if(events[i].events&EPOLLOUT)
{
sockfd = events[i].data.fd;
// printf("\n in the epoll out block");
//sprintf(line,"\n %d \n",n);
coun++;
write(sockfd, line, n);
//设置用于读操作的文件描述符
ev.data.fd=sockfd;
//设置用于注测的读操作事件
ev.events=EPOLLIN|EPOLLET;
//修改sockfd上要处理的事件为EPOLIN
epoll_ctl(epfd,EPOLL_CTL_MOD,sockfd,&ev);
}
}
}
return 0;
}

...全文
149 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
suyangwei 2010-12-28
  • 打赏
  • 举报
回复
你的代码要处理什么消息?
写个发送消息函数,再写个处理消息函数,
把代码封装一下。
suyangwei 2010-12-28
  • 打赏
  • 举报
回复
socket无操作,你的代码不会运行。
代码封装不好。
写个发送消息的函数,再写个处理消息的函数。
walkany 2010-12-28
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 hawk198 的回复:]
看不出来慢啊,你那个

C/C++ code
nfds=epoll_wait(epfd,events,2560,0);
是死等,等待有客户端连接触发才会有响应的
[/Quote]

========================================================

兄弟应该怎么改啊?

hawk198 2010-12-22
  • 打赏
  • 举报
回复
看不出来慢啊,你那个
nfds=epoll_wait(epfd,events,2560,0);
是死等,等待有客户端连接触发才会有响应的
oyster2008 2010-12-21
  • 打赏
  • 举报
回复
怎么个慢法?

19,612

社区成员

发帖
与我相关
我的任务
社区描述
系统使用、管理、维护问题。可以是Ubuntu, Fedora, Unix等等
社区管理员
  • 系统维护与使用区社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧