Python3之源码解读socketserver工作流程

基于TCP套接字的2种循环分为:通信循环和链接循环

socketserver模块既然用来处理并发,那么分为两大类:

解决链接问题的server类,解决通信问题的request类

server类主要有

#处理链路
        +------------+
        | BaseServer |
        +------------+
              |
              v
        +-----------+        +------------------+
        | TCPServer |------->| UnixStreamServer |
        +-----------+        +------------------+
              |
              v
        +-----------+        +--------------------+
        | UDPServer |------->| UnixDatagramServer |
        +-----------+        +--------------------+

#处理多线程并发:
"ThreadingMixIn","ThreadingUDPServer","ThreadingTCPServer"
#处理多进程并发:
"ForkingUDPServer","ForkingTCPServer", "ForkingMixIn"

request类主要有(处理通信循环):

"BaseRequestHandler", "StreamRequestHandler","DatagramRequestHandler"

各类之间的继承关系
forking

handler

threading

Let`s roll:

code:

import socketserver
class FtpServer(socketserver.BaseRequestHandler):
    def handle(self):
        pass
ftpserver = socketserver.ThreadingTCPServer(('127.0.0.1', 8080), FtpServer)
ftpserver.serve_forever()

我们只看TCP协议:

先看下属性的查找顺序:

        +--------------------+
        | ThreadingTCPServer |
        +--------------------+
                  |
                  v
          +----------------+        
          | ThreadingMixIn |
          +----------------+        
                  |
                  v
            +-----------+        
            | TCPServer |
            +-----------+     
                 |
                 v
            +-----------+
            | BaseServer|
            +-----------+

实例化得到ftpserver ,执行TCPServer类的__init__方法,并执行 server_bind()
和self.server_activate():

class TCPServer(BaseServer):
    def __init__(self, server_address, RequestHandlerClass, bind_and_activate=True):
        self.server_bind()
        self.server_activate()

找到ftpserver 下的serve_forever,这个方法在BaseServer下,执行self._handle_request_noblock():

class BaseServer:
    def serve_forever(self, poll_interval=0.5):
        self._handle_request_noblock()

看下self._handle_request_noblock():

def _handle_request_noblock(self):
    #相当于TCPServer中的self.socket.accept()
    request, client_address = self.get_request()
    #接收完请求后处理请求和客户端地址
    self.process_request(request, client_address)

这时找到了ThreadingMixIn的process_request方法,执行process_request_thread方法,:

class ThreadingMixIn:
    def process_request_thread(self, request, client_address):
        self.finish_request(request, client_address)

    def process_request(self, request, client_address):
        """开启新线程处理请求"""
        t = threading.Thread(target = self.process_request_thread,
                             args = (request, client_address))
        t.daemon = self.daemon_threads
        t.start()

到此就完成了链接循环的处理,接着看下通讯循环:

BaseServer中finish_request中:

def finish_request(self, request, client_address):
    """通过实例化类去结束一个请求,实例化一个类触发__init__方法"""
    self.RequestHandlerClass(request, client_address, self)

这里找到了BaseRequestHandler

class BaseRequestHandler:
    def __init__(self, request, client_address, server):
        #调用了对象自己的handle()
        self.handle()

class FtpServer(socketserver.BaseRequestHandler):
    def handle(self):
        pass   

@整个流程分析结束@!!!

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值