

新闻资讯
技术学院Python网络编程进阶核心是多客户端下TCP/UDP服务端的稳定高效实现:TCP用threading加锁或asyncio协程管理连接与状态,UDP需自行识别客户端并设计会话机制,混合场景中TCP负责可靠控制、UDP处理实时数据,上线前须日志、超时、抓包和压力测试。
Python 网络编程进阶,核心不在协议本身,而在如何让服务端稳定、高效地应对多个客户端——尤其是混用 TCP 和 UDP 时的资源协调、状态管理与异常处理。
TCP 是面向连接的,每个客户端需独立维护 socket 和会话状态。传统方式是为每个新连接启动一个线程:
socket.accept() 接收连接后,立即丢给 threading.Thread 处理,主线程继续监听threading.Lock),否则可能丢消息或崩溃concurrent.futures.ThreadPoolExecutor 限制并发数(比如最多 50 个活跃连接)更现代的做法是用 asyncio + async/await:
asyncio.start_server() 启动,每个连接由一个 async def handle_client() 协程接管UDP 不建连接,服务端一个 socket 就能收发所有客户端数据,但“多客户端”意味着你得自己识别是谁发的:
sock.recvfrom(1024) 返回 (data, (ip, port)) —— 这个 (ip, port) 就是客户端地址,必须存下来才能回包b'HELLO',服务端记录其地址并分配 session_id,后续包带该 ID 校验
UDP 没有重传和拥塞控制,丢包常见;关键业务(如指令)建议加应用层确认(ACK 包)+ 超时重发真实场景中,TCP 和 UDP 往往分工协作,不是非此即彼:
multiprocessing.Queue 或 Redis)SO_REUSEPORT 让多个 socket 绑定同一端口(需内核支持),但更稳妥的是明确区分端口,避免冲突本地跑通不等于生产可用:
logging 替代 print,记录连接/断开时间、IP、错误类型(如 ConnectionResetError)、处理耗时settimeout() 防卡死;UDP 的 settimeout() 防 recvfrom 阻塞;asyncio 中用 asyncio.wait_for()
locust 或自写脚本模拟百客户端并发,观察内存增长、CPU 占用、响应延迟拐点