基于多线程实现套接字服务端支持并发

本文介绍了一个基于Python的多线程服务器实现,能够同时处理多个客户端的连接请求,通过线程为每个客户端提供独立的通信服务。服务器监听特定IP和端口,接收客户端消息并以大写形式返回,展示了线程在处理并发IO密集型任务中的应用。
进程池|线程池(同步,异步  阻塞,非阻塞)
多线程:IO密集型
多进程:计算密集型
线程是cpu运行单位,进程是资源单位
from socket import *
from threading import Thread

def comunicat(conn):
    while True:  # 通信循环
        try:
            data = conn.recv(1024)
            if len(data) == 0: break
            conn.send(data.upper())
        except ConnectionResetError:
            break
    conn.close()

def server(ip, port, backlog=5):
    server = socket(AF_INET, SOCK_STREAM)
    server.bind((ip,port))
    server.listen(backlog)

    while True:  # 链接循环
        conn, client_addr = server.accept()
        print(client_addr)

        #通信
        t=Thread(target=comunicat,args=(conn,))
        t.start()

if __name__ == '__main__':
    s=Thread(target=server,args=('127.0.0.1',8081))
    s.start()
服务端
from socket import *

client=socket(AF_INET,SOCK_STREAM)
client.connect(('127.0.0.1',8081))
while True:
    msg=input(">>:").strip()
    if len(msg) == 0: continue
    client.send(msg.encode('utf-8'))
    data=client.recv(1024)
    print(data.decode('utf-8'))
客户端

实现在服务端开启时,可以运行多个客户端,但是有一万个客户端时,服务端会开多个线程来运行,这样就会很耗资源

转载于:https://www.cnblogs.com/zhouhao123/p/10994487.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值