Python selectors

#!/usr/bin/env python
# -*- coding:utf-8 -*-
# author: Changhua Gong

import selectors
import socket

sel = selectors.DefaultSelector()
‘‘‘selectors根据系统自动select或epoll‘‘‘

def accept(sock, mask):
    conn, addr = sock.accept()  # Should be ready
    print(‘accepted‘, conn, ‘from‘, addr)
    conn.setblocking(False)  # 设置连接不阻塞
    sel.register(conn, selectors.EVENT_READ, read) # 新连接注册read回调函数

def read(conn, mask):
    data = conn.recv(1024)  # Should be ready
    if data:
        print(‘echoing‘, repr(data), ‘to‘, conn)
        conn.send(data)  # Hope it won‘t block
    else:
        print(‘closing‘, conn)
        sel.unregister(conn)
        conn.close()

sock = socket.socket()
sock.bind((‘localhost‘, 10000))
sock.listen(100)
sock.setblocking(False)
sel.register(sock, selectors.EVENT_READ, accept)  # 注册sock,有连接进来则调用accept

while True:
    events = sel.select() # 默认阻塞,有活动连接就返回活动的连接列表
    for key, mask in events:
        callback = key.data # accept的内存地址或read的内存地址,即等于read或accept函数
        callback(key.fileobj, mask)  # 调用对应的回调函数,key.fileobj为文件句柄
时间: 2024-10-20 09:22:14

Python selectors的相关文章

Python/selectors模块

Python/selectors模块 selectors模块是可以实现IO多路复用机制: 它具有根据平台选出最佳的IO多路机制,比如在win的系统上他默认的是select模式而在linux上它默认的epoll. 常用共分为三种: select.poll.epoll select的缺点: 1.每次调用都要将所有的文件描述符(fd)拷贝的内核空间,导致效率下降 2.遍历所有的文件描述符(fd)查看是否有数据访问 3.最大链接数限额(1024) poll: 它就是select和epoll的过渡阶段,它

Python - selectors 模块

selectors 模块 它的功能与 linux 的 epoll,还是 select 模块,  poll 等类似: 实现高效的 I/O multiplexing ,  常用于非阻塞的 socket  的编程中 官方文档 这里 内部类 ? BaseSelector ? SelectSelector ? PollSelector ? EpollSelector ? DevpollSelector ? KqueueSelector ? DefaultSelector 实际使用为此类, 自动选择为当前环

python selectors ftp服务端

import selectors import socket,os,sys BASE_DIR= os.path.dirname(os.path.dirname(os.path.abspath(__file__))) sys.path.append(BASE_DIR) sel = selectors.DefaultSelector() cmdlist=['put','get'] class Ftp(object):     def __init__(self):         pass     

python selectors 模块应用

模块使用示例1 import selectors import socket sel = selectors.DefaultSelector() def accept(sock, mask): conn, addr = sock.accept() # Should be ready 建立连接 print('accepted', conn, 'from', addr) conn.setblocking(False) sel.register(conn, selectors.EVENT_READ,

Day15 - Python基础15 模块学习-selectors

本节内容 1:Python/selectors模块 2:selsect实例 1:Python/selectors模块及队列  selectors模块是可以实现IO多路复用机制: 它具有根据平台选出最佳的IO多路机制,比如在win的系统上他默认的是select模式而在linux上它默认的epoll. 常用IO多路复用共分为三种: select.poll.epoll 且windows上只支持select,而linux上都支持 select的缺点: 1.每次调用都要将所有的文件描述符(fd)拷贝的内核

Python编程之基础知识练习_007

练习内容:socket,IO多路复用,Python selectors库,实现简单的群聊. 1.服务端代码 1 __author__ = 'Orcsir' 2 import selectors 3 import threading 4 import socket 5 from collections import namedtuple 6 7 8 class ChatServer: 9 def __init__(self, ip="0.0.0.0", port=9527): 10 se

python之selectors模块

selectors模块是在python3.4版本中引进的,它封装了IO多路复用中的select和epoll,能够更快,更方便的实现多并发效果. 官方文档见:https://docs.python.org/3/library/selectors.html 以下是一个selectors模块的代码示范: #!/usr/bin/python #Author:sean import selectors import socket #selectors模块默认会用epoll,如果你的系统中没有epoll(比

python 协程, 异步IO Select 和 selectors 模块 多并发演示

主要内容 Gevent协程 Select\Poll\Epoll异步IO与事件驱动 selectors 模块 多并发演示 协程 协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程. 协程拥有自己的寄存器上下文和栈.协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时候,恢复先前保存的寄存器上下文和栈.因此: 协程能保留上一次调用时的状态(即所有局部状态的一个特定组合),每次过程重入时,就相当于进入上一次调用的状态,换种说法:进入上一次离开

# 进程/线程/协程 # IO:同步/异步/阻塞/非阻塞 # greenlet gevent # 事件驱动与异步IO # Select\Poll\Epoll异步IO 以及selectors模块 # Python队列/RabbitMQ队列

1 # 进程/线程/协程 2 # IO:同步/异步/阻塞/非阻塞 3 # greenlet gevent 4 # 事件驱动与异步IO 5 # Select\Poll\Epoll异步IO 以及selectors模块 6 # Python队列/RabbitMQ队列 7 8 ############################################################################################## 9 1.什么是进程?进程和程序之间有什么