网络编程问题:TCP/UDP 连接异常解决方案

TCP/UDP 连接异常解决方案代码示例

以下是一个基于 Python 的 TCP/UDP 连接异常处理代码示例,涵盖常见的连接异常场景(如超时、连接拒绝、端口占用等),并提供重试机制和日志记录功能。

TCP 连接异常处理
import socket import time import logging logging.basicConfig(level=logging.INFO) logger = logging.getLogger(__name__) def tcp_connect_with_retry(host, port, max_retries=3, timeout=5): retry_count = 0 while retry_count < max_retries: try: sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) sock.settimeout(timeout) sock.connect((host, port)) logger.info(f"TCP connection established to {host}:{port}") return sock except socket.timeout: logger.warning(f"TCP connection timeout (attempt {retry_count + 1})") except ConnectionRefusedError: logger.error(f"Connection refused by {host}:{port}") except socket.error as e: logger.error(f"Socket error: {str(e)}") finally: retry_count += 1 time.sleep(1) raise ConnectionError(f"Failed to establish TCP connection after {max_retries} retries")

https://www.zhihu.com/zvideo/1994260861682997179/
https://www.zhihu.com/zvideo/1994260861682997179
https://www.zhihu.com/zvideo/1994260860697341967/
https://www.zhihu.com/zvideo/1994260860697341967
https://www.zhihu.com/zvideo/1994260857056671243/
https://www.zhihu.com/zvideo/1994260857056671243
https://www.zhihu.com/zvideo/1994260851021071994/
https://www.zhihu.com/zvideo/1994260851021071994
https://www.zhihu.com/zvideo/1994260850433886062/
https://www.zhihu.com/zvideo/1994260850433886062
https://www.zhihu.com/zvideo/1994260847934066912/
https://www.zhihu.com/zvideo/1994260847934066912
https://www.zhihu.com/zvideo/1994260843584570191/
https://www.zhihu.com/zvideo/1994260843584570191
https://www.zhihu.com/zvideo/1994260839423832246/
https://www.zhihu.com/zvideo/1994260839423832246
https://www.zhihu.com/zvideo/1994260838081664990/
https://www.zhihu.com/zvideo/1994260838081664990
https://www.zhihu.com/zvideo/1994260835078529378/
https://www.zhihu.com/zvideo/1994260835078529378
https://www.zhihu.com/zvideo/1994260833497273482/
https://www.zhihu.com/zvideo/1994260833497273482
https://www.zhihu.com/zvideo/1994260832259966840/
https://www.zhihu.com/zvideo/1994260832259966840
https://www.zhihu.com/zvideo/1994260832532583874/
https://www.zhihu.com/zvideo/1994260832532583874
https://www.zhihu.com/zvideo/1994260827105146355/
https://www.zhihu.com/zvideo/1994260827105146355
https://www.zhihu.com/zvideo/1994260823569364542/
https://www.zhihu.com/zvideo/1994260823569364542
https://www.zhihu.com/zvideo/1994260822684356958/
https://www.zhihu.com/zvideo/1994260822684356958
https://www.zhihu.com/zvideo/1994260818049655700/
https://www.zhihu.com/zvideo/1994260818049655700
https://www.zhihu.com/zvideo/1994260817747674698/
https://www.zhihu.com/zvideo/1994260817747674698
https://www.zhihu.com/zvideo/1994260815390463543/
https://www.zhihu.com/zvideo/1994260815390463543
https://www.zhihu.com/zvideo/1994260811632358143/
https://www.zhihu.com/zvideo/1994260811632358143

UDP 连接异常处理
def udp_send_with_retry(host, port, data, max_retries=3, timeout=5): retry_count = 0 while retry_count < max_retries: try: sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) sock.settimeout(timeout) sock.sendto(data.encode(), (host, port)) logger.info(f"UDP data sent to {host}:{port}") return sock except socket.timeout: logger.warning(f"UDP send timeout (attempt {retry_count + 1})") except socket.error as e: logger.error(f"UDP socket error: {str(e)}") finally: retry_count += 1 time.sleep(1) raise ConnectionError(f"Failed to send UDP data after {max_retries} retries")

https://www.zhihu.com/zvideo/1994266399967815160/
https://www.zhihu.com/zvideo/1994266399967815160
https://www.zhihu.com/zvideo/1994266394804638799/
https://www.zhihu.com/zvideo/1994266394804638799
https://www.zhihu.com/zvideo/1994266393525372736/
https://www.zhihu.com/zvideo/1994266393525372736
https://www.zhihu.com/zvideo/1994266392124466186/
https://www.zhihu.com/zvideo/1994266392124466186
https://www.zhihu.com/zvideo/1994266391612769736/
https://www.zhihu.com/zvideo/1994266391612769736
https://www.zhihu.com/zvideo/1994266391889604666/
https://www.zhihu.com/zvideo/1994266391889604666
https://www.zhihu.com/zvideo/1994266389448504132/
https://www.zhihu.com/zvideo/1994266389448504132
https://www.zhihu.com/zvideo/1994266387447832880/
https://www.zhihu.com/zvideo/1994266387447832880
https://www.zhihu.com/zvideo/1994266387040981461/
https://www.zhihu.com/zvideo/1994266387040981461
https://www.zhihu.com/zvideo/1994266386592199141/
https://www.zhihu.com/zvideo/1994266386592199141
https://www.zhihu.com/zvideo/1994266373937967153/
https://www.zhihu.com/zvideo/1994266373937967153
https://www.zhihu.com/zvideo/1994266375666034264/
https://www.zhihu.com/zvideo/1994266375666034264
https://www.zhihu.com/zvideo/1994266370750301136/
https://www.zhihu.com/zvideo/1994266370750301136
https://www.zhihu.com/zvideo/1994266368053359641/
https://www.zhihu.com/zvideo/1994266368053359641
https://www.zhihu.com/zvideo/1994266368544096292/
https://www.zhihu.com/zvideo/1994266368544096292
https://www.zhihu.com/zvideo/1994266367365490383/
https://www.zhihu.com/zvideo/1994266367365490383
https://www.zhihu.com/zvideo/1994266365352248655/
https://www.zhihu.com/zvideo/1994266365352248655
https://www.zhihu.com/zvideo/1994266364907635656/
https://www.zhihu.com/zvideo/1994266364907635656
https://www.zhihu.com/zvideo/1994266364546942673/
https://www.zhihu.com/zvideo/1994266364546942673
https://www.zhihu.com/zvideo/1994266364588873142/
https://www.zhihu.com/zvideo/1994266364588873142

端口占用检测
def is_port_in_use(port, protocol='tcp'): try: if protocol.lower() == 'tcp': sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM) else: sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) sock.bind(('0.0.0.0', port)) sock.close() return False except socket.error: return True
使用示例
if __name__ == "__main__": # TCP 示例 try: tcp_sock = tcp_connect_with_retry("example.com", 80) tcp_sock.sendall(b"GET / HTTP/1.1\r\nHost: example.com\r\n\r\n") response = tcp_sock.recv(4096) print(response.decode()) except Exception as e: print(f"TCP error: {str(e)}") # UDP 示例 try: udp_sock = udp_send_with_retry("example.com", 53, "test data") data, addr = udp_sock.recvfrom(1024) print(f"Received UDP data from {addr}: {data.decode()}") except Exception as e: print(f"UDP error: {str(e)}") # 端口检测 print(f"Port 80 in use (TCP): {is_port_in_use(80)}") print(f"Port 53 in use (UDP): {is_port_in_use(53, 'udp')}")
关键功能说明
  • 自动重试机制:通过max_retries参数控制最大重试次数
  • 超时处理:通过timeout参数设置连接/发送超时时间
  • 错误分类处理:区分超时、连接拒绝和其他socket错误
  • 日志记录:使用标准logging模块记录连接状态
  • 端口检测:支持检测TCP/UDP端口占用情况

该代码可通过调整参数适应不同网络环境,建议根据实际需求修改重试策略和超时时间。

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

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

相关文章

2025 年程序员转行方向推荐:避开开发内卷,投身网络安全这类紧缺领域,真的不用焦虑了!

对于程序员转行方向的推荐&#xff0c;可以基于当前的技术趋势、市场需求以及程序员的个人技能和兴趣来综合考虑。以下是一些推荐的转行方向&#xff1a; 伴随着社会的发展&#xff0c;网络安全被列为国家安全战略的一部分&#xff0c;因此越来越多的行业开始迫切需要网安人员…

人体姿态估计应用:MediaPipe Pose在医疗中的使用

人体姿态估计应用&#xff1a;MediaPipe Pose在医疗中的使用 1. 引言&#xff1a;AI驱动的医疗康复新范式 随着人工智能技术在计算机视觉领域的深入发展&#xff0c;人体姿态估计&#xff08;Human Pose Estimation&#xff09;正逐步从实验室走向实际应用场景。尤其在医疗健…

Qwen3-0.6B-FP8:0.6B参数解锁双模智能推理

Qwen3-0.6B-FP8&#xff1a;0.6B参数解锁双模智能推理 【免费下载链接】Qwen3-0.6B-FP8 Qwen3 是 Qwen 系列中最新一代大型语言模型&#xff0c;提供全面的密集模型和混合专家 (MoE) 模型。Qwen3 基于丰富的训练经验&#xff0c;在推理、指令遵循、代理能力和多语言支持方面取得…

MediaPipe Pose实战:舞蹈动作捕捉系统

MediaPipe Pose实战&#xff1a;舞蹈动作捕捉系统 1. 引言&#xff1a;AI 人体骨骼关键点检测的现实价值 随着人工智能在计算机视觉领域的深入发展&#xff0c;人体姿态估计&#xff08;Human Pose Estimation&#xff09;已成为智能交互、运动分析、虚拟现实和健康监测等场景…

MediaPipe Pose为何选择CPU优化?能效比实测数据揭秘

MediaPipe Pose为何选择CPU优化&#xff1f;能效比实测数据揭秘 1. 引言&#xff1a;AI人体骨骼关键点检测的现实挑战 随着AI在健身指导、动作捕捉、虚拟试衣和人机交互等场景中的广泛应用&#xff0c;实时人体姿态估计已成为一项基础且关键的技术能力。其中&#xff0c;Goog…

MediaPipe Pose部署成功率100%?零外部依赖方案实测分享

MediaPipe Pose部署成功率100%&#xff1f;零外部依赖方案实测分享 1. 引言&#xff1a;AI人体骨骼关键点检测的落地挑战 在计算机视觉领域&#xff0c;人体姿态估计&#xff08;Human Pose Estimation&#xff09; 是一项基础且关键的技术&#xff0c;广泛应用于健身动作识别…

ImageGPT-medium:用像素预测玩转AI图像生成新技巧

ImageGPT-medium&#xff1a;用像素预测玩转AI图像生成新技巧 【免费下载链接】imagegpt-medium 项目地址: https://ai.gitcode.com/hf_mirrors/openai/imagegpt-medium 导语&#xff1a;OpenAI推出的ImageGPT-medium模型&#xff0c;通过借鉴GPT系列在自然语言处理领域…

display driver uninstaller操作指南:从零实现GPU驱动纯净环境

从蓝屏到丝滑&#xff1a;用DDU重建显卡驱动的“出厂级”纯净环境 你有没有遇到过这样的情况——明明刚更新了最新版显卡驱动&#xff0c;结果开机黑屏、游戏闪退、HDMI没声音&#xff0c;甚至系统直接蓝屏&#xff1f;反复重装也没用&#xff0c;仿佛有个“幽灵驱动”在暗中作…

MediaPipe Pose性能测试:CPU环境下毫秒级推理实战

MediaPipe Pose性能测试&#xff1a;CPU环境下毫秒级推理实战 1. 引言&#xff1a;AI人体骨骼关键点检测的现实需求 随着计算机视觉技术的快速发展&#xff0c;人体姿态估计&#xff08;Human Pose Estimation&#xff09;已成为智能健身、动作捕捉、虚拟试衣、安防监控等场景…

AR交互实战:用MediaPipe Hands镜像快速搭建手势控制应用

AR交互实战&#xff1a;用MediaPipe Hands镜像快速搭建手势控制应用 1. 引言 在增强现实&#xff08;AR&#xff09;和人机交互领域&#xff0c;手势识别正逐渐成为最自然、最直观的输入方式之一。相比传统的鼠标、键盘或触控操作&#xff0c;手势控制让用户“徒手”即可与虚…

无人机交通监管:基于YOLOv8的电动车违规检测方案

无人机交通监管&#xff1a;基于YOLOv8的电动车违规检测方案 1. 引言&#xff1a;电动自行车监管的智能化转型 近年来&#xff0c;电动自行车因其便捷、经济的特点&#xff0c;在我国城市与乡村广泛普及。然而&#xff0c;随之而来的交通安全问题也日益突出。据相关统计&…

YOLOv8鹰眼检测功能测评:CPU版实时性能实测

YOLOv8鹰眼检测功能测评&#xff1a;CPU版实时性能实测 1. 测评背景&#xff1a;工业级目标检测的轻量化需求 在智能制造、智能安防、零售分析等场景中&#xff0c;实时多目标检测已成为核心能力。然而&#xff0c;GPU部署成本高、功耗大&#xff0c;难以在边缘设备或资源受限…

构建自定义I2C HID设备驱动完整指南

手把手教你打造自定义I2C HID设备驱动&#xff1a;从协议到实战你有没有遇到过这样的场景&#xff1f;手头有一块定制的触摸控制器&#xff0c;引脚少、功耗低&#xff0c;只支持I2C接口。你想把它接进Linux系统&#xff0c;却发现evtest里没有新设备出现&#xff1b;dmesg里飘…

Kimi-VL-Thinking:2.8B参数实现卓越视觉推理

Kimi-VL-Thinking&#xff1a;2.8B参数实现卓越视觉推理 【免费下载链接】Kimi-VL-A3B-Thinking 项目地址: https://ai.gitcode.com/MoonshotAI/Kimi-VL-A3B-Thinking 导语 月之暗面&#xff08;Moonshot AI&#xff09;推出的Kimi-VL-A3B-Thinking模型&#xff0c;以…

AI关键点检测优化:MediaPipe Pose性能测试

AI关键点检测优化&#xff1a;MediaPipe Pose性能测试 1. 引言&#xff1a;人体骨骼关键点检测的技术价值与挑战 随着人工智能在视觉领域的深入发展&#xff0c;人体骨骼关键点检测&#xff08;Human Pose Estimation&#xff09;已成为智能健身、动作捕捉、虚拟现实和安防监…

腾讯混元7B:256K长文本+GQA,中文AI性能实测

腾讯混元7B&#xff1a;256K长文本GQA&#xff0c;中文AI性能实测 【免费下载链接】Hunyuan-7B-Instruct-0124 腾讯Hunyuan-7B-Instruct-0124是高性能中文7B大模型&#xff0c;支持256K长文本与GQA技术&#xff0c;推理采用vLLM后端&#xff08;TRT-LLM即将开放&#xff09;&am…

MediaPipe Pose参数详解:33个关节点定位技术揭秘

MediaPipe Pose参数详解&#xff1a;33个关节点定位技术揭秘 1. 引言&#xff1a;AI人体骨骼关键点检测的技术演进 1.1 从动作识别到姿态估计的跨越 随着计算机视觉技术的发展&#xff0c;人体姿态估计&#xff08;Human Pose Estimation&#xff09;已成为智能健身、虚拟试…

【毕业设计】SpringBoot+Vue+MySQL 桂林旅游景点导游平台平台源码+数据库+论文+部署文档

摘要 随着旅游业的快速发展和信息化水平的不断提升&#xff0c;传统旅游服务模式已难以满足游客对个性化、便捷化旅游体验的需求。桂林作为中国著名的旅游城市&#xff0c;拥有丰富的自然景观和人文资源&#xff0c;但游客在规划行程、获取景点信息、预订服务等方面仍面临诸多不…

舞蹈动作分析实战:MediaPipe镜像实现高精度姿态捕捉

舞蹈动作分析实战&#xff1a;MediaPipe镜像实现高精度姿态捕捉 1. 引言&#xff1a;舞蹈动作分析的技术需求与挑战 在现代舞蹈训练、体育康复和虚拟现实内容创作中&#xff0c;精准的人体姿态捕捉已成为核心技术之一。传统动作捕捉依赖昂贵的动捕设备或复杂的多摄像头系统&a…

ERNIE 4.5-A47B:300B参数MoE模型部署全攻略

ERNIE 4.5-A47B&#xff1a;300B参数MoE模型部署全攻略 【免费下载链接】ERNIE-4.5-300B-A47B-Paddle 项目地址: https://ai.gitcode.com/hf_mirrors/baidu/ERNIE-4.5-300B-A47B-Paddle 导语 百度最新发布的ERNIE-4.5-300B-A47B-Paddle模型凭借300B总参数与47B激活参数…