python epoll 并发_Python语言之python并发原理(阻塞、非阻塞、epoll)
本文主要向大家介绍了Python语言之python并发原理(阻塞、非阻塞、epoll),通过具体的内容向大家展示,希望对大家学习Python语言有所帮助。
在Linux系统中
01 阻塞服务端
特征:1对1,阻塞。
1 import socket
2
3 server = socket.socket() #生成套接字对象
4 server.bind(('0.0.0.0', 8000)) #套接字绑定ip和端口,变为监听套接字
5 server.listen(5) #开始监听
6
7 while True:
8 conn, addr = server.accept() #建立连接,生成对等套接字
9 print('用户连接:', addr)
10 while True:
11 try:
12 data = conn.recv(1024)
13 if data == b'Q' or data == b'q':
14 print('用户退出:', addr)
15 break
16 else:
17 print('收到的消息:', data.decode())
18 conn.send(data)
19 except Exception as e:
20 print(e)
21 conn.close()
22 break
02 非阻塞服务端
特征:1对多,轮询,非阻塞,占用资源多。
1 import socket
2
3 server = socket.socket() #创建套接字
4 server.setblocking(False) #把套接字设置为非阻塞
5 server.bind(('0.0.0.0', 8001)) #绑定IP和端口
6 server.listen(5) #监听端口
7
8
9 all_connection = [] #保存已经连接的客户
10 while True:
11 #只管连接的事情
12 try:
13 conn, addr = server.accept() # 建立连接,没有就抛出异常
14 conn.setblocking(False) #设置非阻塞
15 print('用户连接:', addr)
16 all_connection.append(conn)
17 except Exception as e:
18 pass
19
20
21 #处理已经连接用户的消息
22 handle = all_connection.copy() #完全拷贝了列表
23 for connection in handle:
24 try:
25 recv_data = connection.recv(1024)
26 if recv_data:
27 print(recv_data.decode())
28 connection.send(recv_data)
29 else: #客户端消息处理完了,已经断开了连接
30 print('断开连接', connection)
31 connection.close()
32 all_connection.remove(connection) #从客户列表里移除断开连接的客户
33 except Exception as e:
34 pass
03 epoll服务端
特征:1对多,通知机制,非阻塞,占用资源少;epoll:注册惰性事件回调。
1 import selectors #调用epoll的模块
2 import socket
3
4 epoll = selectors.EpollSelector() #生成一个epoll
5 server = socket.socket() #生成套接字
6 server.bind(('', 8082)) #参数1‘’与‘0.0.0.0’等价,表示ip都可接入
7 server.listen(100)
8
9
10 #回调函数
11 def create_conneciton(server):
12 #百分百有人连接,不会阻塞
13 conn, addres = server.accept() #生成对等连接套接字
14
15
16 #处理消息的函数注册
17 epoll.register(conn, selectors.EVENT_READ, read_data)
18 return conn
19
20
21
22 #回调函数 处理消息
23 def read_data(conn):
24
25 data = conn.recv(1024)
26 if data:
27 print(data)
28 conn.send(data)
29 else:
30 epoll.unregister(conn) #删掉注册事件
31
32
33 #1
34 #把监听套接字和生成对等套接字的函数注册到read事件(有用户连接)
35 epoll.register(server, selectors.EVENT_READ, create_conneciton)
36
37
38 #2
39 while True: #事件循环
40 events = epoll.select() #去操作系统查询
41
42 for key,mask in events:
43 sock = key.fileobj #连接客户端的套接字
44 callback = key.data #回调函数
45
46 #read_data(conn), create_conneciton(server)
47 callback(sock) #调用函数
04 客户端
测试服务端。
1 import socket
2
3 client = socket.socket()
4 client.connect(('127.0.0.1', 8082))
5
6 while True:
7 data = input('输入数据:')
8 client.send(data.encode())
9 recv_data = client.recv(1024)
10 print(recv_data.decode())
本文由职坐标整理并发布,希望对同学们学习Python有所帮助,更多内容请关注职坐标编程语言Python频道!
python epoll 并发_Python语言之python并发原理(阻塞、非阻塞、epoll)相关推荐
- python 进程池阻塞和非阻塞_python 之 并发编程(进程池与线程池、同步异步阻塞非阻塞、线程queue)...
9.11 进程池与线程池 池子使用来限制并发的任务数目,限制我们的计算机在一个自己可承受的范围内去并发地执行任务 池子内什么时候装进程:并发的任务属于计算密集型池子内什么时候装线程:并发的任务属于IO ...
- Python|线程和进程|阻塞|非阻塞|同步|异步|生成器和协程|资源竞争|进程间通信|aiohttp库|daemon属性值详解|语言基础50课:学习(11)
文章目录 系列目录 原项目地址 第34课:Python中的并发编程-1 线程和进程 多线程编程 使用 Thread 类创建线程对象 继承 Thread 类自定义线程 使用线程池 守护线程 资源竞争 G ...
- 15分钟读懂进程线程、同步异步、阻塞非阻塞、并发并行,太实用了!
作者:Martin cnblogs.com/mhq-martin/p/9035640.html 基本概念 1 进程和线程 进程(Process): 是Windows系统中的一个基本概念,它包含着一个运 ...
- 15分钟读懂进程线程、同步异步、阻塞非阻塞、并发并行
基本概念 1 进程和线程 进程(Process): 是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.一个正在运行的应用程序在操作系统中被视为一个进程,进程可以包括一个或多个线程 ...
- cpu 被挂起和阻塞_同步异步阻塞非阻塞并发并行讲解
通过一个很形象的例子来说明同步异步阻塞非阻塞. 场景: 小明使用 chrome 下载一个软件. 1. 同步阻塞 小明使用 没有提醒功能的chrome 下载一个软件.小明 一直坐在电脑面前什么事也不做, ...
- python进阶04IO的同步异步,阻塞非阻塞
原创博客地址:python进阶04IO的同步异步,阻塞非阻塞 同步和异步 同步和异步关注的是消息通信机制. 所谓同步,就是在发出一个调用时,在没有得到结果之前,该调用就不返回.但是一旦调用返回,就得到 ...
- 进程线程、同步异步、阻塞非阻塞、并发并行
一.进程和线程 1️⃣[进程Process]是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.一个正在运行的应用程序在操作系统中被视为一个进程,进程可以包括一个或多个线程. 进程 ...
- 并发编程:并发和并行、多进程、同步异步,阻塞非阻塞、进程同步(进程锁)、线程、GIL全局解释器锁、锁-信号量-Event事件、协程
文章目录 一. 操作系统的发展史 二. 进程基础 三. 并发和并行 四. 如何开启多进程 五. 进程调度算法(了解) 六. 同步异步,阻塞非阻塞(了解) 1. 状态介绍 2.同步和异步.阻塞和非阻塞 ...
- 进程线程、同步异步、阻塞非阻塞、并发并行、多线程
一: 进程和线程 1: 进程(Process) 是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.一个正在运行的应用程序在操作系统中被视为一个进程,进程可以包括一个或多个线程.线 ...
最新文章
- doesnt exist table_MYSQL ERROR 1146 Table doesnt exist 解析
- Cogs 376. [IOI2002]任务安排(后效性DP)
- 天河机场RFID技术应用浅析
- python好用的模块_python常用的内置模块和常用的第三方模块
- python怎么查看网页编码格式_Python写爬虫时如果碰到以Request Payload格式传输数据怎么办?...
- 学习网络编程推荐安装的软件
- 计算机网络线接法,电脑网线插座接法图文详解
- 解读 《The Curious Case of Neural Text Degeneration 》 论文 笔记
- 遇到问题---eclipse--java--tomcat运行web项目报错Licensed to the Apache Software Foundation (ASF) under one or m
- SQLite3 获取最小可用ID,ID无需包含1
- 装自己的服务器(教程)yum-jdk-mysql-防火墙-SVN-redis-申请域名
- 关于unity中使用solidwork模型材质及动画丢失问题
- 几款视频剪辑软件,轻松完成视频转换,剪辑
- 2. web前端开发分享-css,js进阶篇
- ora-01172 ora-01151的处理
- 06.破解Windows7密码
- OpenGL环境配置Win7-64位+freeglut+glew+VS2012
- 华为 openlab 鸿蒙,华为OpenLab与工业互联网联盟成立联合生态实验室
- matlab滤波实验,Refined Lee滤波实验MATLAB程序.docx
- 推荐电影: 东北虎, 甘草披萨