Python socketserver模块 – Python量化投资

Python socketserver模块

socketserver模块

简介:socketserver模块是Python内置模块,我们在自己使用socket构建服务端的时候,需要一些设置:

例如代码如下:

import socket
sk = socket.socket()
sk.bind(('127.0.0.1',9001))
sk.listen()
sk.accept()
  # 逻辑区域
sk.close()

但是这种代码的服务端,只能同时帮我们连接一个客户端,也就是说,如果你是一个多个客户端同时连接服务端的程序,这种不支持并发的服务端,肯定是不行的

所以socketserver在内部帮我们封装了支持并发的的服务端构建:

  • ForkingTCPServer(多进程TCP协议服务端)
  • ForkingUDPServer (多进程UDP协议服务端)
  • ThreadingTCPServer(多线程TCP协议服务端)
  • ThreadingUDPServer(多线程UDP协议服务端)

默认情况下我们使用最多的就是ThreadingTCPServer

socketserver基本框架

默认情况下,我们使用的socketserver的框架也都是基本一样的

代码:

import socketserver 
class Myserver(socketserver.BaseRequestHandler): # 继承socketserver.BaseRequestHandler
    def handle(self):  # 必须是handle,socketserver源码里写死的
        self.request # 想到与conn
        pass
if __name__ == '__main__':
    # 这里使用的是 多线程tcp服务端 模块,必须要传的参数是元组式的IP 端口,以及上面的类
    # 这里真正的作用是:socket.socket(),socket.bind(ip 端口),socket.listen()
    server = socketserver.ThreadingTCPServer(('127.0.0.1',9001),Myserver)
    # 这里的作用相当于多线程的accept(),等待连接
    server.serve_forever()

https://www.cnblogs.com/Hybb/p/11495680.html

「点点赞赏,手留余香」

    还没有人赞赏,快来当第一个赞赏的人吧!
0 条回复 A 作者 M 管理员
    所有的伟大,都源于一个勇敢的开始!
欢迎您,新朋友,感谢参与互动!欢迎您 {{author}},您在本站有{{commentsCount}}条评论