Python中IO多路复用socket

本文介绍了如何使用epoll和socket在Python中实现IO多路复用,以提高处理多个网络IO事件的效率。通过避免非阻塞socket的轮询监听,epoll能有效检测socket的读写事件,减少CPU资源浪费。文章包括前言、服务器端(server)、客户端(client)的实现以及整体思路。
摘要由CSDN通过智能技术生成

使用epoll+socket来玩IO多路复用

前言

虽然非阻塞socket能够实现单process同时处理多个网络IO事件(client), 但是socket的setblocking是用不断轮询的方式来达到非阻塞处理client的, 所有难免会浪费CPU资源.

然而, epoll(epoll 为linux中效率最高的 IO多路复用), 计算机底层的机制, 可以来检测send, recv等即检测socket是否发生变化(是否出现读写事件), 避免了socket轮询监听浪费资源.

eg: 如果有客户端连接那么server会变为可读事件(也就是socket有数据了可以进行读操作).


使用

server

import socket
import selectors    # IO多路复用的选择器. 优于select.


def server_accept(sock):
    connected, addr = server.accept()
    sel.register(connected, selectors.EVENT_READ, server_recv)

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值