客户端和服务器已成功建立 TCP 连接【输出解析】
文章目录
- 图片
- **1. 连接状态解析**
- **第一条记录(服务器监听)**
- **第二条记录(客户端 → 服务器)**
- **第三条记录(服务器 → 客户端)**
- **2. 关键概念澄清**
- **(1) `0.0.0.0` 的含义**
- **(2) 端口号的分配规则**
- **3. 为什么服务器端的端口号变成了5046?**
- **4. 验证方法**
- **(1) 客户端代码确认**
- **(2) 多次连接测试**
- **5. 总结**
- **1. `netstat` 输出解析**
- **2. 为什么会有两条 `ESTABLISHED` 记录?**
- **3. 如何验证通信正常?**
- **(1) 客户端控制台输出**
- **(2) 服务器日志验证**
- **4. 后续操作建议**
- **(1) 确认登录成功逻辑**
- **(2) 优化心跳机制(可选)**
- **(3) 处理异常断开**
- **总结**
图片
这里也能看,不过我已经关了
PS C:\Users\14733> netstat -ano | findstr “:54321”
TCP 0.0.0.0:54321 0.0.0.0:0 LISTENING 15380
TCP 192.168.31.222:5046 192.168.31.222:54321 ESTABLISHED 17836
TCP 192.168.31.222:54321 192.168.31.222:5046 ESTABLISHED 15380
根据你的 netstat
输出,我来解释这些数字和状态的含义:
1. 连接状态解析
TCP 0.0.0.0:54321 0.0.0.0:0 LISTENING 15380
TCP 192.168.31.222:5046 192.168.31.222:54321 ESTABLISHED 17836
TCP 192.168.31.222:54321 192.168.31.222:5046 ESTABLISHED 15380
第一条记录(服务器监听)
0.0.0.0:54321
:
0.0.0.0
表示所有可用的网络接口(包括本地回环127.0.0.1
和所有网卡的IP地址)。
服务器程序(PID15380
)正在监听所有接口的54321
端口,等待客户端连接。
第二条记录(客户端 → 服务器)
192.168.31.222:5046 → 192.168.31.222:54321
:5046
是客户端临时端口(由操作系统随机分配,范围通常是1024-65535
)。54321
是服务器固定端口(即你在代码中指定的PORT = 54321
)。- 客户端程序(PID
17836
)通过5046
端口向服务器54321
端口发送数据。
第三条记录(服务器 → 客户端)
192.168.31.222:54321 → 192.168.31.222:5046
:
服务器(PID15380
)通过54321
端口向客户端5046
端口回复数据。
2. 关键概念澄清
(1) 0.0.0.0
的含义
-
监听时:
0.0.0.0:54321
表示服务器监听所有可用网络接口的54321
端口。
客户端可以通过服务器的任何IP地址(如127.0.0.1
、192.168.31.222
或公网IP)连接到该端口。 -
连接时:
0.0.0.0
无意义(因为客户端必须明确指定服务器IP)。
(2) 端口号的分配规则
-
服务器端口(如
54321
):
由程序显式指定,必须唯一且未被其他程序占用。 -
客户端临时端口(如
5046
):
由操作系统随机分配(范围通常是1024-65535
),用于标识客户端进程。
每次新连接建立时,操作系统会分配一个未被使用的临时端口。
3. 为什么服务器端的端口号变成了5046?
这是一个常见误解:
- 服务器始终使用固定端口(如
54321
)接收所有客户端连接。 - 客户端临时端口(如
5046
)是客户端的出口端口,用于区分同一客户端的不同连接。
在你的输出中:
54321
始终是服务器端口(PID15380
)。5046
是客户端(PID17836
)的临时端口,用于与服务器通信。
4. 验证方法
(1) 客户端代码确认
检查客户端连接代码:
s = socket.socket()
s.connect(("192.168.31.222", 54321)) # 客户端明确连接服务器的54321端口
(2) 多次连接测试
每次重启客户端,观察临时端口是否变化:
PS C:\> netstat -ano | findstr ":54321"
# 第一次连接:客户端临时端口可能是5046
# 第二次连接:客户端临时端口可能变为5047、5048等
5. 总结
0.0.0.0:54321
:服务器监听所有接口的54321
端口。5046
:客户端临时端口,由操作系统随机分配,用于本次连接。- 服务器端口始终不变,客户端临时端口每次连接可能不同。
这种设计允许同一客户端同时建立多个到服务器的连接(每个连接使用不同的临时端口),也允许多个客户端同时连接到同一服务器端口。
1. netstat
输出解析
TCP 0.0.0.0:54321 0.0.0.0:0 LISTENING 20060
TCP 192.168.31.222:4376 192.168.31.222:54321 ESTABLISHED 4056
TCP 192.168.31.222:54321 192.168.31.222:4376 ESTABLISHED 20060
-
第一条记录:
0.0.0.0:54321 LISTENING 20060
- 服务器正在监听所有接口的54321端口(进程ID 20060,对应Python服务器程序)。
-
第二、三条记录:
TCP 客户端IP:临时端口 服务器IP:54321 ESTABLISHED 客户端PID TCP 服务器IP:54321 客户端IP:临时端口 ESTABLISHED 服务器PID
- 客户端(IP
192.168.31.222
,临时端口4376
,PID4056
)与服务器(端口54321
,PID20060
)建立了双向连接。 ESTABLISHED
状态表示连接已建立,正在通信(符合预期)。
- 客户端(IP
2. 为什么会有两条 ESTABLISHED
记录?
- TCP连接是双向的:
每条连接包含两个方向的数据流,因此netstat
会显示两个条目,分别表示:- 客户端到服务器的连接(客户端端口 → 服务器端口)
- 服务器到客户端的连接(服务器端口 → 客户端端口)
- 这是正常现象,说明连接完全建立且双向通信畅通。
3. 如何验证通信正常?
(1) 客户端控制台输出
应看到服务器响应的心跳包:
收到服务器响应: b'alive'
这表明客户端发送的 keep_alive
已被服务器正确接收并回应。
(2) 服务器日志验证
服务器日志应显示:
客户端 ('192.168.31.222', 4376) 连接
用户 XXX 登录成功(管理员: ...)
客户端 ('192.168.31.222', 4376) 断开连接(若手动关闭客户端)
或持续记录心跳交互(如 收到 keep_alive
)。
4. 后续操作建议
(1) 确认登录成功逻辑
- 客户端显示
登录成功
弹窗,且能正常接收服务器响应。 - 可在客户端添加更多功能,例如登录后隐藏登录界面,显示上位机主界面。
(2) 优化心跳机制(可选)
- 若不需要持续连接,可在登录成功后按需关闭连接(例如完成验证后断开)。
- 调整心跳间隔(如从5秒改为30秒,减少网络流量):
time.sleep(30) # 修改保活线程的休眠时间
(3) 处理异常断开
- 在客户端和服务器中添加重连逻辑,防止因网络波动导致连接中断后无法自动恢复。
总结
当前 netstat
输出完全正常,说明:
- 服务器已正确监听端口54321;
- 客户端成功连接并保持通信;
- TCP连接双向畅通,数据交互正常。
你可以继续开发上位机的其他功能,或进行跨设备测试(确保防火墙放行端口,使用局域网IP连接)。如果遇到新问题,请提供具体现象或日志,以便进一步分析。
相关文章:

客户端和服务器已成功建立 TCP 连接【输出解析】
文章目录 图片**1. 连接状态解析****第一条记录(服务器监听)****第二条记录(客户端 → 服务器)****第三条记录(服务器 → 客户端)** **2. 关键概念澄清****(1) 0.0.0.0 的含义****(2) 端口号的分配规则** *…...
多标签多分类 用什么函数激活
在多标签多分类任务中,激活函数的选择需要根据任务特性和输出层的设计来决定。以下是常见的激活函数及其适用场景: 一、多标签分类任务的特点 每个样本可以属于多个类别(标签之间非互斥,例如一篇文章可能同时属于 “科技” 和 “…...

day26-计算机网络-4
1. tcp的11种状态 ss -ant -a 表示看所有状态 -n 表示不将ip解析为主机名 -t 表示tcp 1.1. closed状态(客户端、服务端) 客户端发起建立连接前的状态服务端启动服务前的状态 1.2. listen状态(服务端) 服务端软件运行的时候状…...
ngx_stream_geo_module在传输层实现高性能 IP Region 路由
一、模块定位与核心价值 层次:工作在 Stream (TCP/UDP) 层,和 ngx_http_geo_module 的 L7 语义互补。作用:基于客户端 IP 前缀 / 范围生成一个 Nginx 变量,可在后续 proxy_pass、map、limit_conn、access 等指令中使用࿰…...

国防科技大学计算机基础慕课课堂学习笔记
1.信息论 香农作为信息论的这个创始人,给出来了这个信息熵的计算方法,为我们现在的这个生活的很多领域奠定了基础,我第一次听说这个信息熵是在这个数学建模里面的理论学习中有关于这个:决策树的模型,在那个问题里面&a…...

【第七篇】 SpringBoot项目的热部署
简介 本文介绍了热部署(Hot Deployment)的概念、使用场景及在IDEA中的配置方法。热部署可在不重启应用的情况下动态更新代码,提升开发效率,适用于调试、微服务架构和自动化测试等场景。文章详细说明了热部署的实现步骤(…...

解决pycharm同一个文件夹下from *** import***仍显示No module named
1、,from ***import *,同文件夹中已有.py文件但是仍然报错No module named 原因是因为pycharm没有把文件夹设置为根目录,只需要在文件夹的上一级设置为根目录即可,测试过如果仅仅将当前的文件夹设置仍然报错,如果把最上…...
GO 基础语法和数据类型面试题及参考答案(上)
目录 Go 中变量定义方式有哪些?各有什么适用场景? 使用 : 定义变量的限制是什么? 全局变量可以使用 : 声明吗?为什么? Go 中如何声明一个多变量赋值?有哪些注意事项? 常量能否通过表达式赋值…...

使用 Redisson 实现分布式锁—解决方案详解
Redisson 是 Redis 官方推荐的 Java 客户端,提供了一系列分布式服务实现,其中分布式锁是其核心功能之一。本文将深入解析 Redisson 分布式锁的实现原理、高级特性和最佳实践。 一、Redisson 分布式锁的优势 与传统实现的对比 特性手动实现Redisson 实现…...

结合三维基因建模与智能体技术打造工业软件无码平台
通过深度整合 Protocol Buffers (Protobuf)、gRPC 及 Microsoft AI 技术,构建面向智能制造的高性能、智能化 PLM 平台。 一、Protocol Buffers 深度集成 1. 基因模型标准化定义 三维基因容器 Protobuf 规范: protobuf syntax "proto3"; pa…...

Python Day46
Task: 1.不同CNN层的特征图:不同通道的特征图 2.什么是注意力:注意力家族,类似于动物园,都是不同的模块,好不好试了才知道。 3.通道注意力:模型的定义和插入的位置 4.通道注意力后的特征图和热力…...

基于PostGIS的各地级市路网长度统计及Echarts图表可视化实践-以湖南省为例
目录 前言 一、路网长度计算 1、地级市列表查询 2、地级市路网长度查询 二、Echarts可视化实现 1、Echarts后端生成 2、引入Colormap配色 3、前端微调 三、总结 前言 在当今快速发展的社会中,交通路网的建设与布局对于一个地区的经济发展、居民生活以及城市…...

mac版excel如何制作时长版环形图
设置辅助列 创建簇状柱形图 将辅助列绘制在次坐标轴 工作时长在主坐标轴,右键分别更改图表类型为圆环。 辅助列圆环全部为灰色,边框为白色 辅助列设置透明度100% 设置辅助列和工作时长列同样的圆环大小 可得 核心:只要辅助列边框不透明…...
PCB设计教程【大师篇】——STM32开发板原理图设计(电源部分)
前言 本教程基于B站Expert电子实验室的PCB设计教学的整理,为个人学习记录,旨在帮助PCB设计新手入门。所有内容仅作学习交流使用,无任何商业目的。若涉及侵权,请随时联系,将会立即处理 目录 前言 1. 工程创建与前期…...
k8s4部署
configMap configmap概述:数据会存储在etcd数据库,其应用场景主要在应用程序的配置 configmap支持的类型(1)键值对(2)多行数据 pod使用configmap资源有两种常见的方式(1)变量注入&a…...
贝叶斯医学分析中“先验”的如何进行选择(文献解读)
贝叶斯医学分析中“先验”的如何进行选择(文献解读) 作者:Callum Taylor, Kathryn Puxty, Tara Quasim, Martin Shaw 文章标题:Understanding Bayesian analysis of clinical trials: an overview for clinicians 期刊名称&#x…...
【汇编逆向系列】七、函数调用包含多个参数之浮点型- XMM0-3寄存器
目录 1. 汇编代码 1.1 debug编译 1.2 release编译 2. 汇编分析 2.1 浮点参数传递规则 2.2 栈帧rsp的变化时序 2.3 参数的访问逻辑 2.4 返回值XMM0寄存器 3. 汇编转化 3.1 Debug编译 3.2 Release 编译 3.3 C语言转化 1. 汇编代码 上一节介绍了整型的函数传参&#x…...

【MySQL系列】MySQL 执行 SQL 文件
博客目录 一、MySQL 执行 SQL 文件的常见场景二、MySQL 执行 SQL 文件的主要方法1. 使用 MySQL 命令行客户端2. 在 MySQL 交互界面中使用 source 命令3. 使用 MySQL Workbench 等图形化工具4. 使用编程语言接口 三、执行 SQL 文件时的注意事项1. 字符集问题2. 事务处理3. 错误处…...

论文MR-SVD
每个像素 7 个 FLOPs意思: FLOPs(浮点运算次数):衡量算法计算复杂度的指标,数值越小表示运算越高效。含义:对图像中每个像素进行处理时,仅需执行7 次浮点运算(如加减乘除等…...

Java 日期时间类全面解析
Java 日期时间类全面解析:从传统到现代的演进 一、发展历程概览 二、传统日期类(Java 8前) 1. java.util.Date - 日期表示类 Date now new Date(); // 当前日期时间 System.out.println(now); // Wed May 15 09:30:45 CST 2023// 特定时间…...

【工具-Wireshark 抓包工具】
工具-Wireshark 抓包工具 ■ Wireshark 抓包工具■ 通过IP指定查看■■ ■ Wireshark 抓包工具 抓包工具】win 10 / win 11:WireShark 下载、安装、使用 Wireshark下载 阿里云镜像 ■ 通过IP指定查看 ■ ■...
Linux安全机制:从SELinux到Intel SGX的堡垒
Linux安全机制:从SELinux到Intel SGX的堡垒 数字世界的钢铁长城 引言:操作系统的"防御工事" 当服务器每天承受数百万次攻击尝试时,Linux内核的安全机制如同精密的防御系统,在纳秒级时间内做出响应。现代Linux安全架构已…...

设备驱动与文件系统:06 目录与文件
磁盘使用的最后一层抽象:文件系统 今天我们讲第31讲,这一讲将完成磁盘对磁盘使用的最后一层抽象。对此板使用最后一层抽象,抽象出来的是什么呢? 实际上我们使用过磁盘,大家应该有这样的认识,最后不管这个磁…...
C++11 Token Bucket (令牌桶)算法的锁无实现及应用
Token Bucket(令牌桶)算法是一种在流量控制和资源分配领域被广泛应用的技术。它通过约束数据传输速率或任务执行频率,确保系统在资源有限的情况下,能够稳定、高效地运行,避免因突发流量或任务积压而导致的性能下降甚至…...
详细介绍uni-app中Composition API和Options API的使用方法
uni-app 中 Composition API 和 Options API 的使用方法详解 一、Options API(Vue 2.x 传统方式) 1. 基本结构 Options API 通过配置对象的不同选项(如 data、methods、computed 等)组织代码: <template><…...
delphi7 链表 使用方法
在 Delphi 中,链表是一种常见的数据结构,用于存储一系列的元素,其中每个元素都包含一个指向列表中下一个元素的引用。在 Delphi 7 中,你可以手动实现链表,或者使用一些现有的集合类,例如 TList 或者 TLinke…...

Linux 系统中的算法技巧与性能优化
引言 Linux 系统以其开源、稳定和高度可定制的特性,在服务器端、嵌入式设备以及开发环境中得到了极为广泛的应用。对于开发者而言,不仅要掌握在 Linux 环境下实现各类算法的方法,更要知晓如何利用系统特性对算法进行优化,以提升…...

【C++系列】模板类型特例化
1. C模板类型特例化介绍 定义:模板类型特例化(Template Specialization)是C中为模板的特定类型提供定制实现的机制,允许开发者对通用模板无法处理的特殊类型进行优化或特殊处理。 产生标准: C98/03…...

K8S认证|CKS题库+答案| 7. Dockerfile 检测
目录 7. Dockerfile 检测 免费获取并激活 CKA_v1.31_模拟系统 题目 开始操作: 1)、切换集群 2)、修改 Dockerfile 3)、 修改 deployment.yaml 7. Dockerfile 检测 免费获取并激活 CKA_v1.31_模拟系统 题目 您必须在以…...
JAVA 对象 详解
对象 对象结构: 对象头(元数据和指向class的指针)、实例数据、对齐填充 数组对象: 对象头(元数据和指向class的指针)、数组长度、数组数据、对齐填充 对象创建: 一、当Java虚拟机遇到一条…...