并发模型1之accept+fork

本文介绍如何使用Python的ForkingTCPServer实现一个服务器,它通过fork进程处理连接,特别适合连接数不多且计算密集型任务,支持长连接。实例演示了EchoHandler处理客户端数据并保持连接直到断开。
摘要由CSDN通过智能技术生成

一、特性

每次连接fork一个进程,为客户提供服务,具有多进程、阻塞I/O、擅长长连接、利用多核特性、顺序执行等特性。

适合场景:

    1. 连接数不大

    2. 计算响应的工作量远大于fork()的开销

    3. 需要长连接

二、Python实现


from SocketServer import BaseRequestHandler
from SocketServer import ForkingTCPServer

class EchoHandler(BaseRequestHandler):
    def handle(self):
        print("got connect from ", self.client_address)
        while True:
            data = self.request.recv(4096)
            if data: 
                sent = self.request.send(data)
            else:
                print("disconnect ", slef.client_address)
                self.request.close()
                brreak

if __name__ == "__main__":
    listen_addr = ("127.0.0.1", 2021)
    server = ForkingTCPServer(listen_addr, EchoHandler)
    server.serve_forever()

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值