多路复用I/O并发服务器

不采用并发技术,当服务器处理一个客户请求时,会拒绝其他客户端请求,造成其他客户要不断的请求并长期等待。
并发服务器有三种设计方式:
(1)多进程
(2)多线程
(3)多路复用I/O并发服务器
select 函数可以在多个扫描符中选择被激活的描述符。一个进程中有多个客户连接,即存在多个TCP 套接字描述符。select()函数阻塞
直到任何一个描述符被激活,即有数据传输。从而避免了进程为等待一个已连接上的数据而
无法处理其他连接。
说到底就是因为IO这样的太浪费时间了,所以需要在进行IO操作的时候将改socket堵塞

int select(int nfds, fd_set *readfds, fd_set *writefds,fd_set * errorfds, struct timeval *timeout);

readfds: select() 函数监视的可读描述符集合。
writefds: select()函数监视的可写描述符集合。
errorfds: select()函数监视的异常描述符集合。
timeout: select()函数超时结束时间
返回值。如果成功返回总的位数,这些位对应已准备好的描述符。否则返回-1,并在errno
中设置相应的错误码。
FD_ZERO(fd_set *fdset):清空fdset 与所有描述符的联系
FD_SET(int fd, fd_set *fdset):建立描述符fd 与fdset 的联系
FD_CLR(int fd, fd_set *fdset):撤销描述符fd 与fdset 的联系
FD_ISSET(int fd,fd_set *fdset) ::检查与fdset 联系的描述符fd 是否可读写,返回非0表示可读写。
采用select()函数实现I/O 多路复用的基本步骤如下:
(1) 清空描述符集合
(2) 建立需要监视的描述符与描述符集合的联系
(3) 调用select()函数
(4) 检查所有需要监视的描述符,利用FD_ISSET 判断是否准备好
(5) 对已准备好的描述符进行I/O 操作

参考资料:
https://blog.csdn.net/rain_qingtian/article/details/11834513

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值