高并发服务器
- select服务器属于多路I/O转接服务器的其中一种服务器模型
- select能监听的文件描述符个数受限于FD_SETSIZE,一般为1024,单纯改变进程打开
的文件描述符个数并不能改变select监听文件个数 - 解决1024以下客户端时使用select是很合适的,但如果链接客户端过多,select采用
的是轮询模型,会大大降低服务器响应效率,不应在select上投入更多精力
多路I/O转接服务器模型大致如下图一样,select就像是服务器的小助手一样,帮忙服务器处理客户端的请求,这样服务器不需要一直去询问客户端是否有数据需要发送,减缓了服务器的压力。
接下来了解一下select函数的用法
select
#include <sys/select.h>
#include <sys/time.h>
#include <sys/types.h>
#include <unistd.h>
int select(int nfds, fd_set *readfds, fd_set *writefds, fd_set *exceptfds,
struct timeval *timeout);
参数
- nfds: 监控的文件描述符集里最大文件描述符加1,因为此参数会告诉内核检测前多少个文件描述符的状态
- readfds:监控有读数据到达文件描述符集合,传入传出参数
- writefds:监控写数据到达文件描述符集合,传入传出参数
- exceptfds:监控异常发生达文件描述