python基于Process的多进程网络并发

本文探讨了如何使用Python的Process模块实现网络请求的多进程并发,通过并发提高网络操作效率,详细阐述了多进程的创建与管理,并给出具体代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

"""
基于Process的多进程网络并发
    1.创建监听套接字
    2.等待接收客户端请求
    3.客户端连接创建新的进程处理客户端请求
    4.原进程继续等待其他客户请求
    5.如果客户端退出,则销毁对应的进程
Socket服务端:
    1.创建服务器套接字对象
    2.绑定套接字ip地址
    3.开启套接字监听
    4.等待客户端套接字接入
    5.客户套接字接入成功并创建客户端会话套接字,信息接收和发送
    6.关闭创建的客户端临时会话套接字
"""
from multiprocessing import Process
from socket import *
import signal
import sys

# 设置全局变量
HOST = "127.0.0.1"
PORT = 9090
ADDR = (HOST, PORT)


def dispose(val):
    while True:
        data = val.recv(1024)
        if not data:
            break
        print(">>>", data.decode())
        val.send(b"my server")
    val.close()


# 创建tcp套接字
soc = socket(AF_INET, SOCK_STREAM)
# 设置端口立即使用
soc.setsockopt(SOL_SOCKET, SO_REUSEADDR, 1)
# 处理僵尸进程
# signal.signal(signal.SIGCHLD, signal.SIG_IGN)
# 绑定地址
soc.bind(ADDR)
# 开启监听服务
soc.listen(5)
print("Listen the port 9090...")
# 循环处理客户端连接
while True:
    try:
        c, addr = soc.accept()
        print("Connect from", addr)
    except KeyboardInterrupt:
        sys.exit("退出")
    except Exception as e:
        print(e)
    # 创建子进程处理客户端事物
    p = Process(target=dispose, args=(c,))
    p.daemon = True  # 父进程结束所有服务终止
    p.start()
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值