文档章节

epoll使用详解

呼噜呼噜睡翻天
 呼噜呼噜睡翻天
发布于 2015/06/15 23:04
字数 664
阅读 295
收藏 13

简介

 epoll是Linux内核中的一种可扩展IO事件处理机制,最早在Linux2.5.44内核中引入,可被用于代替POSIX select和poll系统调用,并且在具有大量应用程序请求时能够获得较好的性能(此时监控的文件描述符数目非常大,与旧的select和poll系统调用完成操作所需O(n)不同,epoll能在O(1)时间内完成操作,所以性能相当高),epoll与FreeBSD的kqueue类似,都向用户空间提供了自己的文件描述符来进行操作。

int epoll_create(int size);

  创建一个epoll的句柄,size用来告诉内核需要监听的数目一共有多大。当创建好epoll句柄后,它就是会占用一个fd的值,在linux下如果查看/proc/进程id/fd/,是能够看到这个fd的,所以在使用完epoll后,必须调用close()关闭,否则可能导致fd被耗尽。

int epoll_ctl(int epfd, int op, int fd, struct epoll_event *event);

  epoll的事件注册函数,第一个参数是epoll_create()的返回值,第二个参数表示动作,使用如下三个宏来表示:

EPOLL_CTL_ADD    注册新的fd到epfd中;
EPOLL_CTL_MOD    修改已经注册的fd的的监听事件;
EPOLL_CTL_DEL    从epoll中删除一个fd;

 第三个参数是需要监听的fd,第四个参数是告诉内核需要监听什么事件,struct epoll_event结构如下:

typedef union epoll_data {
    void *ptr;
    int fd;
    __uint32_t u32;
    __uint64_t u64;
} epoll_data_t;

struct epoll_event {
    __uint32_t events;
    epoll_data_t data;
}

  events可以是以下几个宏的集合:

EPOLLIN    可读事件
EPOLLOUT    可写事件
EPOLLPRI    表示文件描述符有紧急的数据可读(带外数据)
EPOLLERR    表示文件描述符发生错误
EPOLLHUP    表示文件描述符被挂断
EPOLLET    将EPOLL设为边缘触发模式,相对于水平触发来说
EPOLLONESHOT    只监听一次事件,当监听完这次事件之后,如果还需要继续监听这个socket的话,需要再次把这个socket加入到EPOLL队列里

  当对方关闭连接(FIN),EPOLLERR,都可以认为是一种EPOLLIN事件,在read的时候分别有0,-1两个返回值。

int epoll_wait(int epfd, struct epoll_event *events, int maxevents, int timeout);

  参数events用来从内核得到事件的集合,maxevents告之内核这个events有多大,这个maxevents的值不能大于创建epoll_create()时的size,参数timeout是超时时间(毫秒,0会立即返回,-1永久阻塞)。该函数返回需要处理的事件数目,如返回0表示你已超时。

© 著作权归作者所有

共有 人打赏支持
呼噜呼噜睡翻天
粉丝 28
博文 74
码字总数 36560
作品 0
朝阳
程序员
私信 提问
Epoll模型详解

Linux I/O多路复用技术在比较多的TCP网络服务器中有使用,即比较多的用到select函数。Linux 2.6内核中有提高网络I/O性能的新方法,即epoll 。 1、为什么select落后 首先,在Linux内核中,sel...

sharep
2013/07/23
0
0
基于epoll实现的一个简单的web服务器

本文使用epoll建立一个简单的web服务器。通过epoll实现对过个端口的管理,非阻塞的数据发送。 使用到数据结构 typedef union epoll_data { 详解1 EPOLLIN:文件描述符可以读 所用到的函数: ...

Reage-
2013/03/20
0
4
Epoll详解及源码分析

1.什么是epoll epoll是当前在Linux下开发大规模并发网络程序的热门人选,epoll 在Linux2.6内核中正式引入,和select相似,都是I/O多路复用(IO multiplexing)技术,按照man手册的说法:是为处理...

follitude
2016/07/23
35
0
linux epoll使用详解

Linux2.6内核中epoll用法详解 引言 epoll是linux2.6内核中才有的机制,其他版本内核中是没有的,是Linux2.6内核引入的多路复用IO的一种方式,用于提高网络IO 性能的方法。在linux网络编程中,...

lichao19881026
2014/05/12
0
0
linux epoll使用详解

Linux2.6内核中epoll用法详解 引言 epoll是linux2.6内核中才有的机制,其他版本内核中是没有的,是Linux2.6内核引入的多路复用IO的一种方式,用于提高网络IO 性能的方法。在linux网络编程中,...

xiaot99
2014/02/07
0
0

没有更多内容

加载失败,请刷新页面

加载更多

java环形缓冲区

import java.util.ArrayList;import java.util.List;/** * * 环形缓冲区<br/> * 一. 写数据:<br/> * 1. push: 当数据已写满时返回false,否则可以正常写入返回true<br/>......

whoisliang
19分钟前
1
0
内存性能的正确解读

一台服务器,不管是物理机还是虚拟机,必不可少的就是内存,内存的性能又是如何来衡量呢。 1. 内存与缓存 现在比较新的CPU一般都有三级缓存,L1 Cache(32KB-256KB),L2 Cache(128KB-2MB)...

阿里云官方博客
21分钟前
2
0
并发+超时示例

func installMantisAgent() {log.Println("begin auto repair mantis agent")num := 0succNum := 0failNum := 0var Q *queue.Queueswitch g.Config().RepairType {ca......

我爱吃葱花
34分钟前
1
0
增加一列自增id

ALTER TABLE xxxx ADD iSiteId INT(11) NOT NULL PRIMARY KEY AUTO_INCREMENT FIRST;

colin_86
43分钟前
3
0
配置Tomcat虚拟主机

12月13日任务 16.4 配置Tomcat监听80端口 16.5/16.6/16.7 配置Tomcat虚拟主机 16.8 Tomcat日志 配置tomcat监听80端口 默认tomcat监听的是8080端口,如果想直接输入ip就访问到网页,就需要进行...

robertt15
58分钟前
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部