python-socket-SocketServer - Forking

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python-socket-SocketServer - Forking相关的知识,希望对你有一定的参考价值。

在之前的文章中,客户端和服务端。一般情况下并非是一对一的关系。多对一,多个客户端连接一个服务端。并且服务端需要对每一个客户端进行信息处理。

在客户端不多的情况下,可以采取为每一个客户端创建一个进程对其进行服务。

SocketServer中为Forking架构。

代码说明:

"""
@function test forking request handle
"""

import os
import socket
import SocketServer


class ForkingServer(SocketServer.ForkingMixIn, SocketServer.TCPServer):
    """ no thing to do"""

    pass


class ForkingMsgHandler(SocketServer.BaseRequestHandler):

    def handle(self):
        data = self.request.recv(1024)
        current_process = os.getpid()
        print " the process id is : " + current_process
        response = "Process " + current_process + " send response message"
        self.request.send(response)
        return

if __name__ == ‘__main__‘:
    tcp_server = ForkingServer(("172.0.0.1", 8321), ForkingMsgHandler)

 两个关键类ForkingServer和ForkingMsgHandler

ForkingServer需要继承SocketServer.ForkingMixIn 和 SocketServer.TCPServer.并且不能颠倒顺序。当收到一个来自客户端的请求,Forking一个新的进程在进程中启动TCPserver与其建立连接。

ForkingMsgHander为消息处理类。需要继承SocketServer.BaseRequestHandler.该函数的作用是在一个进程中处理连接后来自客户端的消息。

 

以上是关于python-socket-SocketServer - Forking的主要内容,如果未能解决你的问题,请参考以下文章