高性能服务器程序框架

服务器模型

 

 

 

服务器编程框架 

 

 I/O模型

socket在创建时默认是阻塞的,针对阻塞I/O的系统调用可能因为无法立即完成而被系统挂起,直到等待的事件发生为止。比如客户端connect服务器,如果没有收到服务器返回的确认报文段,就被挂起,直到收到报文并唤醒connect调用。socket的基础API中,被阻塞的系统调用有acceptsend、recvconnect

对于非阻塞I/O执行的系统调用总是立即返回,不管事件是否发生。如果没有发生返回-1,和出错的返回值一样,但是可以通过errno区分。对于accept send  recv而言,事件未发生通常被设置成EAGAIN(再来一次)或者EWOULDBLOCK(期望阻塞),对于connect则是EINPROGRESS(在处理中)。

 

I/O复用函数有select poll和epoll_wait,它们本身是阻塞的,它们能提高程序效率原因在于具有同时监听多个I/O事件的能力。

 

两种高效的事件处理模式 

 

 

 

 

两种高效的并发模式  

 

有限状态机

其实就是switch数据结构 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值