前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python socket多线程和多进程

python socket多线程和多进程

作者头像
py3study
发布2020-01-07 16:33:54
1.1K0
发布2020-01-07 16:33:54
举报
文章被收录于专栏:python3

在socket中,如果直接创建的话,是只能接受一个用户的请求 需要实现socketserver中的handle方法,可以实现多进程并发访问

SocketServer内部使用 IO多路复用 以及 “多线程” 和 “多进程” ,从而实现并发处理多个客户端请求的Socket服务端。即:每个客户端请求连接到服务器时,Socket服务端都会在服务器是创建一个“线程”或者“进 程” 专门负责处理当前客户端的所有请求。

1、创建一个继承自 socketserver.BaseRequestHandler 的类,类中必须定义一个名称为 handle 的方法 2、启动ThreadingTCPServer

代码语言:javascript
复制
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()
代码语言:javascript
复制
客户端直接使用原来的客户端代码即可。

ThreadingTCPServer ThreadingTCPServer实现的Soket服务器内部会为每个client创建一个 “线程”,该线程用来和客户端进行交互。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019/09/11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档