python实现并发服务器的几种方式

本文介绍了一种使用Python的socket模块创建并发服务器的方法,通过多进程和多线程方式处理客户端连接,实现了服务器的高并发能力。

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

3.使用多进程和多线程的方式实现并发服务器

import socket
from multiprocessing import Process
from threading import Thread


def task(sock):
    while True:
        try:
            recv_data = sock.recv(1024)
            if recv_data:
                print('accept data:', recv_data.decode())
                sock.sendall(recv_data)
            else:
                break
        except ConnectionResetError as e:
            print('close connecting.', e)
            break
    sock.close()


def main():
    sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
    sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    sock.bind(('', 8001))
    sock.listen(5)
    while True:
        conn, addr = sock.accept()
        print('Connected by:', addr)
        # Process(target=task, args=(conn, )).start()     # 使用多进程
        Thread(target=task, args=(conn, )).start()


if __name__ == '__main__':
    main()

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值