0

0

Python socket 通信的完整流程

冰川箭仙

冰川箭仙

发布时间:2026-01-30 13:28:02

|

885人浏览过

|

来源于php中文网

原创

不需要,socket.connect() 是客户端行为,底层自动分配本地端口;服务端才需 bind() + listen();客户端提前 bind() 通常导致 Address already in use 错误。

python socket 通信的完整流程

socket.connect() 前必须先调用 socket.bind() 吗?

不需要,而且通常不能这么做。socket.connect() 是客户端行为,它主动发起连接,底层会自动分配本地端口(ephemeral port),无需也不能提前 bind() —— 除非你明确需要固定源端口(比如某些防火墙策略或调试场景)。服务端才需要 bind() + listen()

常见错误现象:

  • 客户端代码里写了 sock.bind(('localhost', 8080)) 再调 connect(),结果报错 OSError: [Errno 48] Address already in use 或直接失败
  • 混淆了服务端的绑定逻辑,误以为“所有 socket 都要先 bind”

正确做法:

  • 客户端:创建 socket → 直接 connect()
  • 服务端:创建 socket → bind()listen()accept()

recv() 为什么会卡住、返回空字节或截断数据?

recv() 是底层系统调用,它不保证一次收完应用层消息,只按 TCP 缓冲区当前可用字节数返回。这是最常被忽略的设计事实。

立即学习Python免费学习笔记(深入)”;

典型表现:

  • 发送 b'HELLO\nWORLD\n',但 recv(1024) 可能只返回 b'HELLO\n',下次才收到 b'WORLD\n'
  • 对端关闭连接后,recv() 返回空 bytes(b''),不是错误,是正常 EOF 信号
  • 若发送方发得快、接收方 recv 得慢,TCP 窗口机制可能导致粘包或拆包

解决方案取决于协议设计:

  • 简单命令行工具:约定每条消息以换行符结尾,用 makefile().readline() 或循环拼接直到遇到 \n
  • 二进制协议:在包头写明长度(如前 4 字节为 int 表示 body 长度),先 recv 固定 4 字节,再按长度 recv 剩余部分
  • 不要用 recv(1024) 硬切,尤其当消息长度不确定时

为什么 close() 之后还可能收到 FIN 或 RST?

TCP 是全双工协议,close() 默认触发的是「半关闭」流程:它先发 FIN 给对端,但本端仍可读取已到达的剩余数据。真正不可读要等对方也 FIN,或超时后内核清理。

网趣购物系统加强升级版
网趣购物系统加强升级版

新版本程序更新主要体现在:完美整合BBS论坛程序,用户只须注册一个帐号,即可全站通用!采用目前流行的Flash滚动切换广告 变换形式多样,受人喜爱!在原有提供的5种在线支付基础上增加北京云网支付!对留言本重新进行编排,加入留言验证码,后台有留言审核开关对购物系统的前台进行了一处安全更新。在原有文字友情链接基础上,增加LOGO友情链接功能强大的6种在线支付方式可选,自由切换。对新闻列表进行了调整,

下载

容易踩的坑:

  • 客户端调用 sock.close() 后立刻退出,但服务端刚发出的响应还在网络中,导致丢数据
  • 忽略 shutdown(socket.SHUT_WR),误以为 close() 会立即切断写方向
  • 使用 SO_LINGER 选项强制等待(不推荐),可能阻塞主线程

稳妥做法:

  • 发完数据后,调用 sock.shutdown(socket.SHUT_WR) 显式关闭写端
  • 再循环 recv() 直到返回 b'',确保读完对端响应
  • 最后 close()

Python 中 socket.settimeout() 和 select() 该怎么选?

settimeout() 简单直接,适合单连接、控制流清晰的场景;select()(或更现代的 selectors)用于单线程管理多个 socket,避免阻塞。

关键差异:

  • settimeout(5.0) 让每个 recv()/connect() 最多等 5 秒,超时抛 socket.timeout(继承自 OSError
  • select([sock], [], [], 5.0) 同时监控多个 socket 的可读/可写状态,返回就绪列表,不阻塞整个线程
  • Windows 下 select() 不支持管道和普通文件,而 settimeout() 无此限制

实际建议:

  • 脚本类小工具:用 settimeout() + 异常捕获足够
  • 需同时处理客户端连接和服务端监听(如简单 echo server):优先用 selectors.DefaultSelector,比手写 select() 更健壮
  • 不要混用:给 socket 设了 timeout 还拿去传给 select(),timeout 会被忽略

TCP 连接建立和关闭的细节、缓冲区行为、以及 Python socket 对底层 errno 的封装,才是真正决定通信是否稳定的关键。写几行 demo 很容易,但让它们在弱网、高并发、异常中断下依然可靠,得抠清楚每个系统调用的语义边界。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

463

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

544

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

113

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

200

2025.08.29

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

523

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

523

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

788

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1129

2023.07.27

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

0

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.7万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号