本文主要向大家介绍了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)相关推荐

  1. python 进程池阻塞和非阻塞_python 之 并发编程(进程池与线程池、同步异步阻塞非阻塞、线程queue)...

    9.11 进程池与线程池 池子使用来限制并发的任务数目,限制我们的计算机在一个自己可承受的范围内去并发地执行任务 池子内什么时候装进程:并发的任务属于计算密集型池子内什么时候装线程:并发的任务属于IO ...

  2. Python|线程和进程|阻塞|非阻塞|同步|异步|生成器和协程|资源竞争|进程间通信|aiohttp库|daemon属性值详解|语言基础50课:学习(11)

    文章目录 系列目录 原项目地址 第34课:Python中的并发编程-1 线程和进程 多线程编程 使用 Thread 类创建线程对象 继承 Thread 类自定义线程 使用线程池 守护线程 资源竞争 G ...

  3. 15分钟读懂进程线程、同步异步、阻塞非阻塞、并发并行,太实用了!

    作者:Martin cnblogs.com/mhq-martin/p/9035640.html 基本概念 1 进程和线程 进程(Process): 是Windows系统中的一个基本概念,它包含着一个运 ...

  4. 15分钟读懂进程线程、同步异步、阻塞非阻塞、并发并行

    基本概念 1 进程和线程 进程(Process): 是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.一个正在运行的应用程序在操作系统中被视为一个进程,进程可以包括一个或多个线程 ...

  5. cpu 被挂起和阻塞_同步异步阻塞非阻塞并发并行讲解

    通过一个很形象的例子来说明同步异步阻塞非阻塞. 场景: 小明使用 chrome 下载一个软件. 1. 同步阻塞 小明使用 没有提醒功能的chrome 下载一个软件.小明 一直坐在电脑面前什么事也不做, ...

  6. python进阶04IO的同步异步,阻塞非阻塞

    原创博客地址:python进阶04IO的同步异步,阻塞非阻塞 同步和异步 同步和异步关注的是消息通信机制. 所谓同步,就是在发出一个调用时,在没有得到结果之前,该调用就不返回.但是一旦调用返回,就得到 ...

  7. 进程线程、同步异步、阻塞非阻塞、并发并行

    一.进程和线程 1️⃣[进程Process]是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.一个正在运行的应用程序在操作系统中被视为一个进程,进程可以包括一个或多个线程. 进程 ...

  8. 并发编程:并发和并行、多进程、同步异步,阻塞非阻塞、进程同步(进程锁)、线程、GIL全局解释器锁、锁-信号量-Event事件、协程

    文章目录 一. 操作系统的发展史 二. 进程基础 三. 并发和并行 四. 如何开启多进程 五. 进程调度算法(了解) 六. 同步异步,阻塞非阻塞(了解) 1. 状态介绍 2.同步和异步.阻塞和非阻塞 ...

  9. 进程线程、同步异步、阻塞非阻塞、并发并行、多线程

    一: 进程和线程 1: 进程(Process) 是Windows系统中的一个基本概念,它包含着一个运行程序所需要的资源.一个正在运行的应用程序在操作系统中被视为一个进程,进程可以包括一个或多个线程.线 ...

最新文章

  1. doesnt exist table_MYSQL ERROR 1146 Table doesnt exist 解析
  2. Cogs 376. [IOI2002]任务安排(后效性DP)
  3. 天河机场RFID技术应用浅析
  4. python好用的模块_python常用的内置模块和常用的第三方模块
  5. python怎么查看网页编码格式_Python写爬虫时如果碰到以Request Payload格式传输数据怎么办?...
  6. 学习网络编程推荐安装的软件
  7. 计算机网络线接法,电脑网线插座接法图文详解
  8. 解读 《The Curious Case of Neural Text Degeneration 》 论文 笔记
  9. 遇到问题---eclipse--java--tomcat运行web项目报错Licensed to the Apache Software Foundation (ASF) under one or m
  10. SQLite3 获取最小可用ID,ID无需包含1
  11. 装自己的服务器(教程)yum-jdk-mysql-防火墙-SVN-redis-申请域名
  12. 关于unity中使用solidwork模型材质及动画丢失问题
  13. 几款视频剪辑软件,轻松完成视频转换,剪辑
  14. 2. web前端开发分享-css,js进阶篇
  15. ora-01172 ora-01151的处理
  16. 06.破解Windows7密码
  17. OpenGL环境配置Win7-64位+freeglut+glew+VS2012
  18. 华为 openlab 鸿蒙,华为OpenLab与工业互联网联盟成立联合生态实验室
  19. matlab滤波实验,Refined Lee滤波实验MATLAB程序.docx
  20. 推荐电影: 东北虎, 甘草披萨

热门文章

  1. 【收藏】wiztree大文件查找软件
  2. spark Docker镜像构建及push脚本
  3. linux 获取CPU NUMA内存节点信息
  4. 【收藏】win10利用WSL2安装docker的2种方式
  5. Scala流程控制语句值顺序控制
  6. scala中的构造方法和伴生对象
  7. python3数据类型:Number(数字)
  8. eureka源码:开启eureka server
  9. Spring MVC--使用Jackson返回JSON格式数据
  10. Java异常中受检异常非受检异常与RuntimeException异常关系