多路I/O转接服务器

Posted xd_xumaomao

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了多路I/O转接服务器相关的知识,希望对你有一定的参考价值。

多路IO转接服务器也叫做多任务IO服务器。该类服务器实现的主旨思想是,不再由应用程序自己监视客户端连接,取而代之由内核替应用程序监视文件。

主要使用的方法有三种:

select

  1. select能监听的文件描述符个数受限于FD_SETSIZE,一般为1024,单纯改变进程打开的文件描述符个数并不能改变select监听文件个数
  2. 解决1024以下客户端时使用select是很合适的,但如果链接客户端过多,select采用的是轮询模型,会大大降低服务器响应效率,不应在select上投入更多精力

select函数原型:

//select函数是用来监视一个或多个文件句柄的状态变化的,可阻塞也可不阻塞。
int select(int nfds, fd_set *readfds, fd_set *writefds,fd_set *exceptfds, struct timeval *timeout);

struct timeval {
    long tv_sec; /* seconds */
    long tv_usec; /* microseconds */
};
void FD_CLR(int fd, fd_set *set); //把文件描述符集合里fd清0
int FD_ISSET(int fd, fd_set *set); //测试文件描述符集合里fd是否置1
void FD_SET(int fd, fd_set *set); //把文件描述符集合里fd位置1
void FD_ZERO(fd_set *set);         //把文件描述符集合里所有位清0

参数:

nfds:       监控的文件描述符集里最大文件描述符加1,因为此参数会告诉内核检测前多少个文件描述符的状态

readfds:   监控有读数据到达文件描述符集合,传入传出参数

writefds:  监控写数据到达文件描述符集合,传入传出参数

exceptfds: 监控异常发生到达文件描述符集合,传入传出参数

timeout:   定时阻塞监控时间,3种情况:

                  1.NULL,永远等下去

                  2.设置timeval,等待固定时间

                  3.设置timeval里时间均为0,检查描述字后立即返回,轮询

以上是关于多路I/O转接服务器的主要内容,如果未能解决你的问题,请参考以下文章

IO多路转接 ——— selectpollepoll

多路I/O转接服务器

实现多路转接I/O——select服务器

I/O多路转接之select和非阻塞IO

基于TCP协议 I/O多路转接(select) 的高性能回显服务器客户端模型

Linux网络编程基于TCP流 I/O多路转接(poll) 的高性能http服务器