select、 poll、 epool

IO  input  output

在内存中存在数据交换的操作

内存和磁盘交换  文件读写  打印

内存和网络交换  recv  send

 

IO密集型程序 : 程序执行中执行大量的IO操作,而较少需要cpu运算 消耗cpu资源少,运行周期往往较长

 

cpu密集型程序: 程序执行中需要大量的cpu运算,IO操作较少。占用cpu多

 

 

IO分类

 

阻塞IO :默认形态 是效率最低的一种IO

 

阻塞 : 因为等待某种条件达成再继续运行  

                例如 accept recv input

 

                处理IO事件的时候耗时较长也会产生阻塞

                例如 文件的读写过程,网络数据的传输过程

 

非阻塞IO : 通过修改IO对象使其变为非阻塞状态(改变第一种阻塞形态)

 

通常用循环不断判断阻塞条件,需要消耗更多cpu但是一定程度上提高了IO效率

 

 

s.setblocking()

功能 : 将套接字设置的阻塞状态

参数 : bool 默认为True  设置为False则为非阻塞

 

超时等待(检测)

 

cookie

 

更专业的打印异常信息

import  traceback

trancback.print_exc()

 

s.settimeout()

功能 : 设置套接字的超时监测

参数 : 超时时间

 

所谓超时监测即 对原本阻塞的函数进行设置,使其不再始终阻塞,而是阻塞等待一定时间后自动返回。在规定时间中如果正常结束阻塞则继续执行否则产生timeout异常

select   join()   wait

 

IO多路复用

 

定义 : 同时监控多个IO事件,当哪个IO事件准备就绪就执行哪个IO事件,形成并发的效果

 

import  select

 

select ------》 win   linux  unix

poll  -----》 linux、unix

epoll

 

r,w,x = select(rlist,wlist,xlist,[timeout])

功能 :监控IO事件,阻塞等待IO事件发生

参数 :rlist   列表  存放我们要监控等待处理的IO

 

       wlist   列表  存放我们希望主动处理的IO

 

             xlist   列表  存放如果发生异常需要我们处理的

            

             timeout  数字  超时监测 默认一直阻塞

 

返回值 : r  列表  rlist当中准备就绪的IO

                    w  列表  wlist当中准备就绪的IO

                    x  列表  xlist当中准备就绪的IO

 

IO多路复用注意点:

1. 在处理io过程中不应发生死循环(某个IO单独占有服务器)

2. io多路复用是单进程程序,是一个并发程序

3. io多路复用有较高的IO 执行效率

 

 

poll

 

1. 创建poll对象

p = select.poll()

 

2. 加入关注的IO

p.register(s)

p.unregister(s)  从关注IO中删除

 

3. 使用poll函数监控

events = p.poll()

功能 : 阻塞等待register的事件只要有任意准备就绪即返回

返回值:events   [(fileno,event),(),()]

 

4. 处理发生的IO事件

 

poll io事件

POLLIN  POLLOUT POLLUP   POLLERR POLLPRI  POLLVAL

rlist   wlist   断开连接  xlist  紧急处理 无效数据

 

s & POLLIN

 

 

epoll

 

* 效率上比poll和select稍微高

* 只能用于linux  unix

* 支持边缘触发  select  poll只支持水平触发

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
最近在开发im服务器 需要大并发链接 QT默认的是使用select模型的 这种轮询方式非常慢 在高并发连接 我们需要epoll才能发挥linux服务器的性能 而且使用简单 整个服务端代码架构无需修改 直接可以使用 只要在 main文件添加: int main int argc char argv[] { #ifdef Q OS LINUX QCoreApplication::setEventDispatcher new EventDispatcherLibEvent ; qInstallMessageHandler customMessageHandler ; #endif QCoreApplication a argc argv ; auto ser new ConfigServer; ser >startServer ; return a exec ; } 在 pro文件添加 linux{ LIBS + levent core SOURCES + common eventdispatcher libevent eventdispatcher libevent cpp common eventdispatcher libevent eventdispatcher libevent config cpp common eventdispatcher libevent eventdispatcher libevent p cpp common eventdispatcher libevent socknot p cpp common eventdispatcher libevent tco eventfd cpp common eventdispatcher libevent tco pipe cpp common eventdispatcher libevent tco cpp common eventdispatcher libevent timers p cpp HEADERS + common eventdispatcher libevent common h common eventdispatcher libevent eventdispatcher libevent h common eventdispatcher libevent eventdispatcher libevent config h common eventdispatcher libevent eventdispatcher libevent config p h common eventdispatcher libevent eventdispatcher libevent p h common eventdispatcher libevent libevent2 emul h common eventdispatcher libevent qt4compat h common eventdispatcher libevent tco h common eventdispatcher libevent wsainit h } 可以直接跨平台了使用了 csdn博客:http: blog csdn net rushroom">最近在开发im服务器 需要大并发链接 QT默认的是使用select模型的 这种轮询方式非常慢 在高并发连接 我们需要epoll才能发挥linux服务器的性能 而且使用简单 整个服务端代码架构无需修改 直接可以使用 只要在 main文件添加: [更多]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值