Python 官方文档:入门教程 => 点击学习
在Socket中,如果直接创建的话,是只能接受一个用户的请求需要实现socketserver中的handle方法,可以实现多进程并发访问 SocketServer内部使用 io多路复用 以及 “多线程” 和 “多进程” ,从而实现并发处理
在Socket中,如果直接创建的话,是只能接受一个用户的请求
需要实现socketserver中的handle方法,可以实现多进程并发访问
SocketServer内部使用 io多路复用 以及 “多线程” 和 “多进程” ,从而实现并发处理多个客户端请求的Socket服务端。即:每个客户端请求连接到服务器时,Socket服务端都会在服务器是创建一个“线程”或者“进 程” 专门负责处理当前客户端的所有请求。
1、创建一个继承自 socketserver.BaseRequestHandler 的类,类中必须定义一个名称为 handle 的方法
2、启动ThreadingtcpServer
import socketserver
class MyServer(socketserver.BaseRequestHandler):
def handle(self):
conn = self.request
conn.sendall("我是一个多线程".encode())
Flag = True
while Flag:
data = conn.recv(1024)
if data.decode() == "exit":
Flag = False
conn.sendall(data)
if __name__ == "__main__":
server = socketserver.ThreadingTCPServer(('127.0.0.1',8009),MyServer)
server.serve_forever()
客户端直接使用原来的客户端代码即可。
ThreadingTCPServer
ThreadingTCPServer实现的Soket服务器内部会为每个client创建一个 “线程”,该线程用来和客户端进行交互。
--结束END--
本文标题: python socket多线程和多进程
本文链接: https://www.lsjlt.com/news/189168.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0