1.创建epoll
windows下只有select,epoll在linux下才有
import socket,selectors
创建socket
server = socket.socket()
绑定ip和端口
server.bind(('',6969))
监听
server.listen(1000)
创建epoll监视器
epoll_selector = selectors.DefaultSelector()
DefaultSelector() 方法根据操作系统自己选择,在linux下用 epoll_selector=selectors.EpollSelector()
2.创建回调函数
注册server
epoll_selector.register(主服务socket,事件类型,回调函数)
epoll_selector.register(server,selectors.EVENT_READ,accept)
回调函数
def accept(soc):
接收数据
conn,addr = soc.accept()
把对等连接注册到epoll监视器
epoll_selector.register(conn,selectors.EVENT_READ,recv)
def recv(soc):
data = soc.recv(1024)
if data:
soc.send(data)
else:
删除注册
epoll_selector.unregister(soc)
soc.close()
3.循环监听
while True:
events = epoll_selector.select()
epoll_selector.select() 会引发阻塞,events会返回一个元祖的列表。
for key , mark in events:
sock = key.fileobj
callback = key.data
callback就是accept()函数, key.fileobj是一个socket对象,将其作为参数传入函数,执行回调函数。
callback(sock)
本文详细介绍如何在Linux环境下使用epoll进行高效网络编程。通过创建epoll监视器,注册socket及事件,实现数据接收与发送的回调函数。文章涵盖epoll的基础设置、事件监听循环及回调函数的设计。
238

被折叠的 条评论
为什么被折叠?



