客户端和服务器已成功建立 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地址)。
    服务器程序(PID 15380)正在监听所有接口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
    服务器(PID 15380)通过 54321 端口向客户端 5046 端口回复数据。

2. 关键概念澄清

(1) 0.0.0.0 的含义
  • 监听时0.0.0.0:54321 表示服务器监听所有可用网络接口54321 端口。
    客户端可以通过服务器的任何IP地址(如 127.0.0.1192.168.31.222 或公网IP)连接到该端口。

  • 连接时0.0.0.0 无意义(因为客户端必须明确指定服务器IP)。

(2) 端口号的分配规则
  • 服务器端口(如 54321):
    由程序显式指定,必须唯一且未被其他程序占用。

  • 客户端临时端口(如 5046):
    由操作系统随机分配(范围通常是 1024-65535),用于标识客户端进程。
    每次新连接建立时,操作系统会分配一个未被使用的临时端口。

3. 为什么服务器端的端口号变成了5046?

这是一个常见误解:

  • 服务器始终使用固定端口(如 54321)接收所有客户端连接。
  • 客户端临时端口(如 5046)是客户端的出口端口,用于区分同一客户端的不同连接。

在你的输出中:

  • 54321 始终是服务器端口(PID 15380)。
  • 5046 是客户端(PID 17836)的临时端口,用于与服务器通信。

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,PID 4056)与服务器(端口 54321,PID 20060)建立了双向连接。
    • ESTABLISHED 状态表示连接已建立,正在通信(符合预期)。

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 输出完全正常,说明:

  1. 服务器已正确监听端口54321;
  2. 客户端成功连接并保持通信;
  3. TCP连接双向畅通,数据交互正常。

你可以继续开发上位机的其他功能,或进行跨设备测试(确保防火墙放行端口,使用局域网IP连接)。如果遇到新问题,请提供具体现象或日志,以便进一步分析。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/news/908996.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Win系统下的Linux系统——WSL 使用手册

我们在复现一些项目的时候,有些依赖包只能在 linux 环境下使用,还不打算使用远程服务器,那么此时我们可以使用 WSL 创建一个 ubutu 系统,在这个系统里创建虚拟环境、下载依赖包。然后,我们就可以在 windows 下的 vscod…

电脑同时连接内网和外网的方法,附外网连接局域网的操作设置

对于工作一般都设置在内网网段中,而同时由于需求需要连接外网,一般只能通过内网和外网的不断切换进行设置,如果可以同时连接内网和外网会更加便利,同时连接内网和外网方法具体如下。 一、电脑怎么弄可以同时连接内网和外网&#…

C++11:原子操作与内存顺序:从理论到实践的无锁并发实现

文章目录 0.简介1.并发编程需要保证的特性2.原子操作2.1 原子操作的特性 3.内存顺序3.1 顺序一致性3.2 释放-获取(Release-Acquire)3.3 宽松顺序(Relaxed)3.4 内存顺序 4.无锁并发5. 使用建议 0.简介 在并发编程中,原子性、可见性和有序性是…

oracle 归档日志与RECOVERY_FILE_DEST 视图

1. RECOVERY_FILE_DEST 视图的作用 RECOVERY_FILE_DEST 是 Oracle 数据库用于 管理快速恢复区(Fast Recovery Area, FRA) 的一个视图。FRA 是 Oracle 提供的一种集中存储恢复相关文件(如归档日志、备份文件、闪回日志等)的区域。…

零基础玩转物联网-串口转以太网模块如何快速实现与MQTT服务器通信

目录 1 前言 2 环境搭建 2.1 硬件准备 2.2 软件准备 2.3 驱动检查 3 MQTT服务器通信配置与交互 3.1 硬件连接 3.2 开启MQTT服务器 3.3 打开配置工具读取基本信息 3.4 填写连接参数进行连接 3.5 通信测试 4 总结 1 前言 MQTT:全称为消息队列遥测传输协议(…

六、Sqoop 导出

作者:IvanCodes 日期:2025年6月7日 专栏:Sqoop教程 Apache Sqoop 不仅擅长从关系型数据库 (RDBMS) 向 Hadoop (HDFS, Hive, HBase) 导入数据,同样也强大地支持反向操作——将存储在 Hadoop 中的数据导出 (Export) 回关系型数据库。…

数据结构-如果将堆结构应用到TOP-K问题上会怎样?

数据结构的应用-如何用堆解决TOP-K问题 前言一、TOP-K问题是什么?二、如何用堆解决TOP-K问题1.怎么建堆,建大堆还是小堆?2.代码实现 总结 前言 本篇文章进行如何用堆结构解决TOP-K问题的讲解 一、TOP-K问题是什么? TOP-k问题&am…

Elasticsearch的索引

正向索引和倒排索引 什么是正向索引? 传统的数据库采用正向索引,如MySQL将表中的id创建索引,正向索引在进行不是id为索引进行搜索的时候,会逐条进行查询,比方说 上图的表格,数据库进行逐条查询,…

分散电站,集中掌控,安科瑞光伏云平台助力企业绿色转型

本项目位于香港全境共计52个分布式光伏站,总装机容量8.6MW。发电模式自发自用,余电上网,逆变器采用阳光电源SG100CX、SG20RT等12种型号共计103台,其余型号共计15台。每个站点均配置气象站。 项目采用AcrelCloud-1200分布式光伏运…

开发记录:修复一些Bug,并实现两个功能

开发记录: 📋 工作概述 到今天主要完成了AI阅读助手的两大核心功能:前情提要和名词解释,并对相关交互体验进行了优化。通过流式SSE技术实现了实时AI内容生成,大幅提升了用户体验。 🎯 主要完成功能 1…

LLM基础1_语言模型如何处理文本

基于GitHub项目:https://github.com/datawhalechina/llms-from-scratch-cn 工具介绍 tiktoken:OpenAI开发的专业"分词器" torch:Facebook开发的强力计算引擎,相当于超级计算器 理解词嵌入:给词语画"…

【HarmonyOS 5.0】开发实战:从UI到Native全解析

一、环境搭建与项目创建 ​​跨平台安装​​ DevEco Studio支持Windows/macOS系统,安装包集成HarmonyOS SDK、Node.js和OHPM工具链。 Windows:双击.exe选择非中文路径macOS:拖拽.app至Applications目录验证:通过Help > Diagnos…

零知开源——STM32F103RBT6驱动 ICM20948 九轴传感器及 vofa + 上位机可视化教程

STM32F1 本教程使用零知标准板(STM32F103RBT6)通过I2C驱动ICM20948九轴传感器,实现姿态解算,并通过串口将数据实时发送至VOFA上位机进行3D可视化。代码基于开源库修改优化,适合嵌入式及物联网开发者。在基础驱动上新增…

华为OD最新机试真题-食堂供餐-OD统一考试(B卷)

题目描述 某公司员工食堂以盒饭方式供餐。 为将员工取餐排队时间降低为0,食堂的供餐速度必须要足够快,现在需要根据以往员工取餐的统计信息,计算出一个刚好能达成排队时间为0的最低供餐速度。即,食堂在每个单位时间内必须至少做出 多少价盒饭才能满足要求。 输入描述 第1行…

【笔记】MSYS2 的 MINGW64 环境 全面工具链

#工作记录 MSYS2 的 MINGW64 环境(mingw64.exe),下面是为该环境准备的最全工具链安装命令(包括 C/C、Python、pip/wheel、GTK3/GTK4、PyGObject、Cairo、SDL2 等)。 这一环境适用于构建原生 64 位 Windows 应用程序。…

基于 HTTP 的单向流式通信协议SSE详解

SSE(Server-Sent Events)详解 🧠 什么是 SSE? SSE(Server-Sent Events) 是 HTML5 标准中定义的一种通信机制,它允许服务器主动将事件推送给客户端(浏览器)。与传统的 H…

【react+antd+vite】优雅的引入svg和阿里巴巴图标

1.安装相关包 由于是vite项目,要安装插件来帮助svg文件引入进来,否则会失败 npm下载包 npm i vite-plugin-svgr vite.config.ts文件内: import svgr from "vite-plugin-svgr"; //... export default defineConfig({plugins: …

UI框架-通知组件

UI框架-通知组件 介绍 一个基于 Vue 3 的轻量级通知组件库,提供了丰富的消息通知功能。支持多种通知类型、自定义样式、进度条显示等特性。 特性 🎨 支持多种通知类型:信息、成功、警告、错误⏳ 支持进度条显示🔄 支持加载中状…

WordZero:让Markdown与Word文档自由转换的Golang利器

在日常工作中,我们经常需要在Markdown和Word文档之间进行转换。Markdown方便编写和版本控制,而Word文档更适合正式的商务环境。作为一名Golang开发者,我开发了WordZero这个库,专门解决这个痛点。 项目背景 GitHub仓库&#xff1…

计算机网络面试汇总(完整版)

基础 1.说下计算机网络体系结构 计算机网络体系结构,一般有三种:OSI 七层模型、TCP/IP 四层模型、五层结构。 简单说,OSI是一个理论上的网络通信模型,TCP/IP是实际上的网络通信模型,五层结构就是为了介绍网络原理而折…