URN Logo
UNIX Resources » Linux » China Linux Forum » C/C++编程版 » 36 » 关于2.6内核 epoll()的效率与使用框架,敬请各位大峡!
announcement 声明: 本页内容为中国Linux论坛的内容镜像,文章的版权以及其他所有的相关权利属于中国Linux论坛和相应文章的作者,如果转载,请注明文章来源及相关版权信息。
Resources
China Linux Forum(finished)
Linux Forum(finished)
FreeBSD China(finished)
linuxforum.net
  业界新闻与评论
  自由软件杂谈
  IT 人生
  Linux软件快递
  翻译作坊
  Linux图书与评论
  GNU Emacs/XEmacs
  Linux 中文环境和中文化
  Linux桌面与办公软件
  Linux 多媒体与娱乐版
  自由之窗Mozilla
  笔记本电脑上的Linux
  Gentoo
  Debian 一族
  网络管理技术
  Linux 安装与入门
  WEB服务器和FTP服务器
  域名服务器和邮件服务器
  Linux防火墙和代理服务器应用
  文件及打印服务器
  技术培训与认证
  Linux内核技术
  Linux 嵌入技术
  Linux设备驱动程序
  Linux 集群技术
  LINUX平台数据库
  系统和网络安全
  CPU 与 编译器
  系统计算研究所专栏
  Linux下的GUI软件开发
  C/C++编程版
  PHP 技 术
  Java&jsp技术
  Shell编程技术
  Perl 编 程
  Python 编 程
  XML/Web Service 技术
  永远的Unix
  FreeBSD世界
   
关于2.6内核 epoll()的效率与使用框架,敬请各位大峡!
 
 
 
 
 
Subject: 关于2.6内核 epoll()的效率与使用框架,敬请各位大峡!
Author: lan_wjz    Posted: 2005-03-25 15:18    Length: 645 byte(s)
[Original] [Print] [Top]
我最近测试了一下epoll()的效率,情况很不理想,感觉比poll()还要差一大截,不知道怎么搞的...
可能是我的程序框架不好,有哪位大峡能提供一个网络应用服务器的框架吗?谢谢!
我的程序结构:

epoll_create()
listen(MAX)
for(;;)
{
x=epoll_wait()
for(i=0;i<x;i++)
{
if(listen)
/* add listen in queue */
epoll_ctl()
if(read)
/* reading */
epoll_ctl()
if(write)
/* writing */
epoll_ctl()
}
}
[Original] [Print] [Top]
Subject: Re: 关于2.6内核 epoll()的效率与使用框架,敬请各位大峡!
Author: h_falls    Posted: 2005-03-25 20:55    Length: 14 byte(s)
[Original] [Print] [Top]
用 libevent 吧
[Original] [Print] [Top]
Subject: Re: 关于2.6内核 epoll()的效率与使用框架,敬请各位大峡!
Author: mechgouki    Posted: 2005-03-26 12:46    Length: 383 byte(s)
[Original] [Print] [Top]
libevent 应该是工作于LT模式下的,和高速的ET还是有差距的,不过ET模式只能用于no-block fd

http://www.kegel.com/rn/ 这边有很好的例子

另外,那个listen的FD也是可以加入epoll的,因为accept实际上也是一种read,你代码中 epoll_ctl()似乎多了点


[Original] [Print] [Top]
Subject: Re: 关于2.6内核 epoll()的效率与使用框架,敬请各位大峡!
Author: gxcooo    Posted: 2005-03-26 22:29    Length: 246 byte(s)
[Original] [Print] [Top]
http://www.gelato.org/pdf/Illinois/gelato_IL2004_epoll_brecht.pdf

如果使用TCP的话,LT和ET差不了多少
----
[Original] [Print] [Top]
Subject: Re: 关于2.6内核 epoll()的效率与使用框架,敬请各位大峡!
Author: mechgouki    Posted: 2005-03-27 11:18    Length: 554 byte(s)
[Original] [Print] [Top]
这个完整的paper 的名字叫<&#65279;Comparing and Evaluating epoll, select, and poll Event Mechanisms> google应该
可以找到

它用了hp的一个研究项目&#65279;来对比这些接口,其实对我们正确使用epoll很有帮助,只所以在前几个测试种epoll没有什么优势它分析出来是过多的&#65279;epoll_ctl 造成---这个可能和这个server本身有关,它是http的,可能需要频繁的更改其FD,一般来说epoll_ctl越少越好.


不过最后一个用idle conns模拟同时连接数还是指出了epoll的效用,这也是epoll设计的本质
[Original] [Print] [Top]
« Previous thread
如何让程序在指定的cpu上运行?
C/C++编程版
36
Next thread »
为什么一个函数写到共享库里就出错?(内附可执行代码)
     

Copyright © 2007 UNIX Resources Network, All Rights Reserved.      About URN | Privacy & Legal | Help | Contact us
备案序号: 京ICP备05006143    webmaster: webmaster@unixresources.net
This page created on 2008-07-17 03:53:05, cost 0.053773880004883 ms.