linux pool函数,linux sys epool(转)

Epoll为我们带来什么

Q:网络服务器的瓶颈在哪?

A:IO效率。

在大家苦苦的为在线人数的增长而导致的系统资源吃紧上的问题正在发愁的时候,Linux 2.6内核中提供的System Epoll为我们提供了一套完美的解决方案。传统的select以及poll的效率会因为在线人数的线形递增而导致呈二次乃至三次方的下降,这些直接导致了网络服务器可以支持的人数有了个比较明显的限制。

自从Linux提供了/dev/epoll的设备以及后来2.6内核中对/dev/epoll设备的访问的封装(System Epoll)之后,这种现象得到了大大的缓解,如果说几个月前,大家还对epoll不熟悉,那么现在来说的话,epoll的应用已经得到了大范围的普及。

那么究竟如何来使用epoll呢?其实非常简单。

通过在包含一个头文件#include 以及几个简单的API将可以大大的提高你的网络服务器的支持人数。

首先通过create_epoll(int maxfds)来创建一个epoll的句柄,其中maxfds为你epoll所支持的最大句柄数。这个函数会返回一个新的epoll句柄,之后的所有操作将通过这个句柄来进行操作。在用完之后,记得用close()来关闭这个创建出来的epoll句柄。

之后在你的网络主循环里面,每一帧的调用epoll_wait(int epfd, epoll_event events, int max events, int timeout)来查询所有的网络接口,看哪一个可以读,哪一个可以写了。基本的语法为:

nfds = epoll_wait(kdpfd, events, maxevents, -1);

其中kdpfd为用epoll_create创建之后的句柄,events是一个epoll_event*的指针,当epoll_wait这个函数操作成功之后,epoll_events里面将储存所有的读写事件。max_events是当前需要监听的所有socket句柄数。最后一个timeout 是epoll_wait的超时,为0的时候表示马上返回,为-1的时候表示一直等下去,直到有事件范围,为任意正整数的时候表示等这么长的时间,如果一直没有事件,则范围。一般如果网络主循环是单独的线程的话,可以用-1来等,这样可以保证一些效率,如果是和主逻辑在同一个线程的话,则可以用0来保证主循环的效率。

epoll_wait范围之后应该是一个循环,遍利所有的事件:

for(n = 0; n < nfds; ++n) {

if(events[n].data.fd == listener) { //如果是主socket的事件的话,则表示有新连接进入了,进行新连接的处理。

client = accept(listener, (struct sockaddr *) &local, &addrlen);

if(client < 0){

perror("accept");

continue;

}

setnonblocking(client); // 将新连接置于非阻塞模式

ev.events = EPOLLIN | EPOLLET; // 并且将新连接也加入EPOLL的监听队列。

注意,这里的参数EPOLLIN | EPOLLET并没有设置对写socket的监听,如果有写操作的话,这个时候epoll是不会返回事件的,如果要对写操作也监听的话,应该是EPOLLIN | EPOLLOUT | EPOLLET

ev.data.fd = client;

if (epoll_ctl(kdpfd, EPOLL_CTL_ADD, client, &ev) < 0) {

// 设置好event之后,将这个新的event通过epoll_ctl加入到epoll的监听队列里面,这里用EPOLL_CTL_ADD来加一个新的 epoll事件,通过EPOLL_CTL_DEL来减少一个epoll事件,通过EPOLL_CTL_MOD来改变一个事件的监听方式。

fprintf(stderr, "epoll set insertion error: fd=%d0, client);

return -1;

}

}

else // 如果不是主socket的事件的话,则代表是一个用户socket的事件,则来处理这个用户socket的事情,比如说read(fd,xxx)之类的,或者一些其他的处理。

do_use_fd(events[n].data.fd);

}

对,epoll的操作就这么简单,总共不过4个API:epoll_create, epoll_ctl, epoll_wait和close。

如果您对epoll的效率还不太了解,请参考我之前关于网络游戏的网络编程等相关的文章。

世界变了,原来担心的问题,现在已经不是问题了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: "epoll read errno" 其实是指 Epoll 系统调用在进行读取操作时出现的错误编号。Epoll 是 Linux 系统中的一个高性能的 I/O 事件通知机制,用于监听文件描述符上的事件并进行相应的处理。当 Epoll 进行读取操作时,可能会发生各种错误,造成读取失败。 其中,errno 是一个全局变量,用于保存最后一次发生错误时的错误编号。 通常情况下,epoll read errno 可能的取值和对应的含义如下: 1. EAGAIN 或 EWOULDBLOCK:表示当前没有可读取的数据,即阻塞状态。 2. EBADF 或 EINVAL:表示被监听的文件描述符无效或者不是一个合法的 socket。 3. EINTR:表示 Epoll 被信号中断,需要重新调用。 4. EFAULT:表示需要读取数据的缓冲区指针无效。 5. ENOMEM:表示内存不足,无法为 Epoll 内部数据结构分配内存空间。 6. 其他错误:比如权限问题、文件已关闭等。 当程序中出现 "epoll read errno" 错误时,我们可以根据具体的错误编号来判断错误的原因,并采取相应的处理措施。可能的处理方法包括:重新尝试读取、更新监听的文件描述符、增加缓冲区大小、检查文件描述符的权限、检查内存使用等。具体的解决方法需要根据实际情况来定,以确保程序的正常运行。 ### 回答2: "epool read errno" 是一个错误信息,通常在使用 Linux 系统中的 epoll I/O 多路复用机制时出现。 在 epoll I/O 多路复用中,使用一个 epoll 对象来监视多个文件描述符(包括套接字和文件)的状态变化。当一个文件描述符准备好进行读操作时,epoll_wait 函数会返回,并且可以通过相应的文件描述符进行读取操作。然而,有时候在调用 epoll_wait 函数时,可能会收到 "epool read errno" 错误。 这个错误通常是由于以下几种情况引起的: 1. epoll 对象没有正确初始化或被关闭了。在使用 epoll_create 函数创建 epoll 对象时,如果返回值为 -1,就说明出错了。 2. epoll_wait 函数的返回值小于 0,表示出错。可以通过读取 errno 变量来获取具体的错误代码。 3. epoll_wait 函数的超时时间参数设置错误,导致超时立即返回,而不是等待任何事件的到来。 解决这个问题的方法包括: 1. 确保正确初始化并正确使用 epoll 对象。如果 epoll_create 函数返回 -1,可以检查 errno 变量来获取具体的错误信息,并相应地处理。 2. 针对 epoll_wait 函数的返回值小于 0 的情况,可以读取 errno 变量来获取具体的错误代码,并进行相应的处理措施。 3. 检查 epoll_wait 函数的超时时间参数是否正确设置。 总之,"epool read errno" 错误是在使用 epoll I/O 多路复用机制时可能会遇到的错误信息,我们需要根据具体的场景和错误代码来进行分析和处理。 ### 回答3: "epoll read errno" 是指使用 epoll 函数进行读操作时出现的错误。epoll 是 Linux 系统中一种高效的 I/O 多路复用机制,允许程序同时监视多个文件描述符,等待其中任何一个文件描述符变为可读或可写状态。而 "epoll read errno" 表示在使用 epoll 进行读操作时出现了错误。 通常,"epoll read errno" 错误的产生是由于以下几个常见原因: 1. 文件描述符错误:epoll 函数对于读操作要求输入参数是一个有效的文件描述符,如果文件描述符无效或已关闭,就会导致 "epoll read errno" 错误。 2. 读取缓冲区不足:当 epoll 函数读取数据时,需要提供一个足够大的缓冲区来存储读取的数据。如果缓冲区不够大,读取的数据可能会被截断,也可能导致 "epoll read errno" 错误。 3. 连接中断或错误状态:在使用 epoll 进行读操作时,如果连接中断或发生错误,epoll 函数会返回相应的错误码,比如 EPIPE、ECONNRESET 等,表示连接发生了错误,从而引发 "epoll read errno" 错误。 为了解决 "epoll read errno" 错误,可以采取以下措施: 1. 检查文件描述符的有效性,确保它是一个有效的、打开的文件描述符。 2. 确保读取缓冲区足够大,可以容纳要读取的数据。 3. 分析错误码,如 EPIPE、ECONNRESET 等,找到具体的错误原因并进行相应的处理。 总之,"epoll read errno" 错误是指在使用 epoll 函数进行读取操作时发生的错误。可以通过检查文件描述符的有效性、确保读取缓冲区足够大以及分析错误码等方式来解决该错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值