Server端:

import socket
import selectors

class Server(object):
def init(self,sel,sock):
self.sel = sel
self.sock = sock

def run(self,host,port):
self.sock.bind((host,port))
self.sock.listen(50)
self.sock.setblocking(False)#设置非阻塞
self.sel.register(sock,selectors.EVENT_READ,self.accept)
while True:
events = self.sel.select()#默认是阻塞,有活动连接就返回活动连接列表
for key,mask in events:
callback = key.data#创建一个回调函数并获取
callback(key.fileobj,mask)#调用回调函数 def accept(self,sock,mask):
conn,addr = sock.accept()#已经就绪,等待接收
print ('连接来自于{}'.format(addr))
conn.setblocking(False)
# sock.send(str('thanks').decode())
sel.register(conn,selectors.EVENT_READ,self.read)#注册事件 def read(self,conn,mask):
data = conn.recv(1024)#就绪,等待接收数据
if data:#判断是否有数据过来,有就执行
print ('来自客户端:',data)
conn.send(data)
else:
print ('准备关闭连接',conn)
sel.unregister(conn)
conn.close()

if name == 'main':
sel = selectors.DefaultSelector()#默认的选择方式
sock = socket.socket()
sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR,1)
host,port = '127.0.0.1',10011
server_obj = Server(sel,sock)
server_obj.run(host,port)

Client端:

import socket
import selectors
import random

sel = selectors.DefaultSelector()

def write(sock):
sock.send(str(random.randint(0,99)).encode('utf-8'))#发送必须是一个byts的数据,需要转码
sel.unregister(sock)#当发送成功后必须取消注册,用与接下来的接收(读)到数据的注册
sel.register(sock,selectors.EVENT_READ,read)#注册一个读的事件

def read(sock):
data = sock.recv(1024)
if not data:#判断接收到的数据是否为空数据
sel.unregister(sock)#当接收完成后,依然是取消注册
sock.close()#到此和服务器的请求基本处理完成,关闭套接字
return
print ('receiver server %s' %data)

for i in range(1000):#开1000个客户端测试
client = socket.socket()
client.setsockopt(socket.SOL_SOCKET,socket.SO_REUSEADDR,1)#防止编辑器的每次运行端口冲突问题
client.connect(('localhost',10011))
sel.register(client,selectors.EVENT_WRITE,write)#注册一个写的事件,接下来处理发送(写)事件的处理

while True:
all_event = sel.select()
print (allevent)
for event,
 in all_event:
sock = event.fileobj
callback = event.data#创建一个回调函数,方便触发事务执行
callback(sock)#调用刚创建的回调函数

python socket 网络编程selector用法 (实用)的更多相关文章

  1. Python Socket 网络编程

    Socket 是进程间通信的一种方式,它与其他进程间通信的一个主要不同是:它能实现不同主机间的进程间通信,我们网络上各种各样的服务大多都是基于 Socket 来完成通信的,例如我们每天浏览网页.QQ ...

  2. Python Socket 网络编程 (客户端的编程)

    Socket 是进程间通信的一种方式,它与其他进程间通信的一个主要不同是:它能实现不同主机间的进程间通信,我们网络上各种各样的服务大多都是基于 Socket 来完成通信的,例如我们每天浏览网页.QQ ...

  3. 25 python socket网络编程

    一 客户端/服务器架构 1.硬件C/S架构(打印机) 2.软件C/S架构 互联网中处处是C/S架构 如黄色网站是服务端,你的浏览器是客户端(B/S架构也是C/S架构的一种) 腾讯作为服务端为你提供视频 ...

  4. Python Socket网络编程详解

    Socket 简介 socket通常也称作"套接字",用于描述IP地址和端口,是一个通信链的句柄,应用程序通常通过"套接字"向网络发出请求或者应答网络请求. s ...

  5. Python - Socket网络编程 - 第二十六天

    网络编程 Python 提供了两个级别访问的网络服务.: 低级别的网络服务支持基本的 Socket,它提供了标准的 BSD Sockets API,可以访问底层操作系统Socket接口的全部方法. 高 ...

  6. python socket网络编程之粘包问题详解

    一,粘包问题详情 1,只有TCP有粘包现象,UDP永远不会粘包 你的程序实际上无权直接操作网卡的,你操作网卡都是通过操作系统给用户程序暴露出来的接口,那每次你的程序要给远程发数据时,其实是先把数据从用 ...

  7. python——socket网络编程

    一.OSI七层模型

  8. 初学Python——Socket网络编程

    认识socket socket本质上就是在2台网络互通的电脑之间,架设一个通道,两台电脑通过这个通道来实现数据的互相传递.我们知道网络 通信 都 是基于 ip+port(端口) 方能定位到目标的具体机 ...

  9. Python socket网络编程(通信介绍)

      socket通信介绍 通信介绍(一) 1.所有网络协议的基础就是:socket 2.socket对TCP与UDP协议封装,让用户进行简单操作. 3.socket只做两件事:发 send,收 rec ...

随机推荐

  1. C# DataTable 通过Linq分组

    datatable我们是经常使用到的,但是需要对数据进行分组,具体代码如下: var result = dt.AsEnumerable().GroupBy(f => new { type = f ...

  2. Axure 动态面板的状态与尺寸

    知识点: 1.动态面板的状态下相当动态面版的模式,当符合某种条件的话就选择对应的动态面板的状态 2.动态面板的尺寸可以根据内容自动调整大小 本节教程主要分为一下图片两种场景: 出现动态面板中的两种.一 ...

  3. BGP - 2,BGP报文和BGP状态

    1,BGP报文      Open:建邻居,交换version.AS号.holdtime.BGP identifier(即RouterID).可选参数长度.可选参数.      Keepalive:保 ...

  4. 使用C#读取网站相对路径文件夹下所有图片

    public JsonResult GetCourseInitCover() { //设置相对路径 string imgurl = Server.MapPath("~/Content/ima ...

  5. 【PowerDesigner】【7】Table视图显示Comment

    原理:把显示name的列的值,替换成注释的值. 步骤:打开菜单Tools>Execute Commands>Edit/Run Script.. 或者用快捷键 Ctrl+Shift+X.将下 ...

  6. CF-503div2-A/B/C

    A. New Building for SIS time limit per test 1 second memory limit per test 256 megabytes input stand ...

  7. MinGW安装教程( MinGW - Minimalist GNU for Windows)

    首先说明一下 1) MinGw只是其中一种GCC编译环境的安装程序,还有像Cygwin也是差不多的; 2) 还要就是安装MinGw,最好在一个网络比较好的环境中进行,  (有可能导致后来安装其他软件像 ...

  8. 二十二、Spring MVC与Structs2的区别总结

    一.框架的入口 1.Structs2采用Filter(StructsPrepartAndExecuteFilter)来进行实现. 2.SpringMVC采用Servlet(DispatcherServ ...

  9. IntelliJ IDEA下载及安装,破解

    IntelliJ IDEA下载及安装,破解 百度百科:IDEA 全称IntelliJ IDEA,是java语言开发的集成环境,IntelliJ在业界被公认为最好的java开发工具之一,尤其在智能代码助 ...

  10. 浅谈MSSQL2012中的列存储索引(columnstore indexes)

    列存储索引为MSSQL2012版本中引进的一个新特性.所有版本MSSQL中标准查询处理模式采用一次一行模型,操作符每次处理一行数据.列存储索引中增加了一种新的基于向量的查询执行功能,通过这种功能,操作 ...