IO多路复用
定义:同时监控多个IO事件,当哪个IO事件准备就绪就执行哪个IO事件。以此形成可以同时执行多个IO的行为,避免一个IO阻塞造成其它IO均无法执行,提供了IO执行效率。
1) select方法在select模块中
from select import select
"""
功能:监控IO事件,阻塞等待IO发生
参数:
rlist 列表 存放关注的等待IO读事件
wlist 列表 存放关注的等待IO写事件
xlist 列表 存放关注的出现异常要处理的IO事件
timeout: 超时
返回值:
rs 列表 rlist中准备就绪的IO
ws 列表 wlist中准备就绪的IO
xs 列表 xlist中准备就绪的IO
"""
rs, ws, xs = select(rlist, wlist, xlist[, timeout])
2) 基于select方法编写的服务端select_server.py:
#!/bin/env python3
from select import select
import socket
s = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
s.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
s.bind(("0.0.0.0", 80))
s.listen(3)
rlist = [s]
wlist = []
xlist = []
while True:
# 监控IO
rs, ws, xs = select(rlist, wlist, xlist)
# 遍历返回值列表,处理就绪的IO
for r in rs:
if r is s:
c, addr = r.accept()
print("connect from ", addr)
rlist.append(c)
c.send("connect successfully!\n".encode())
else:
data = r.recv(1024).decode()
if not data:
rlist.remove(r)
r.close()
continue
print(data,end=' ')
r.send("Server receive OK\n".encode())
for w in ws:
pass
for x in xs:
pass
3) 运行select_server.py方法:服务器端等待客户端连接
[root@gyl-baidu python]# chmod +x select_server.py
[root@gyl-baidu python]# ./select_server.py
4) 用两个客户端连接这个服务器:
用linux的nc命令作为客户端,连接服务器的方法nc -t ip port
-t:指明使用tcp协议 ip:指定服务器地址 port:指定服务器端口
如果当前系统中没有nc命令,请使用yum install netcat安装。
- client1
[root@gyl-baidu ~]# nc -t 127.0.0.1 80
connect successfully!
hello world
Server receive OK
hello client1
Server receive OK
- client2
[root@gyl-baidu ~]# nc -t 127.0.0.1 80
connect successfully!
hello client2
Server receive OK
- server:可以同时接收两个客户端连接,然后处理客户端发来的消息并且回发确认信息。
[root@gyl-baidu python]# ./select_server.py
connect from ('127.0.0.1', 40770)
hello world
hello client1
connect from ('127.0.0.1', 40772)
hello client2