当前位置: 首页 > article >正文

udp多点通信和心跳包

刷题

# UDP多点通信核心要点
## 基础通信模式
### 单播通信
- 一对一通信方式
- UDP默认通信模式
- 地址指向具体目标主机
### 广播通信
- 一对多通信机制
- 地址范围:`xxx.xxx.xxx.255`
- 仅限局域网传输
- 需设置SO_BROADCAST标志
### 组播通信
- 多对多群组通信
- 地址范围:224.0.0.0~239.255.255.255
- 需加入组播IP(IP_ADD_MEMBERSHIP)
## 核心函数配置
### setsockopt参数
#### 通用配置
- `SO_REUSEADDR`:端口复用
- `SO_RCVTIMEO`:接收超时
- `SO_SNDTIMEO`:发送超时
#### 广播配置
- `SO_BROADCAST`:广播权限
- 绑定地址:`255.255.255.255`
#### 组播配置
- `IP_ADD_MEMBERSHIP`:加入组播
- `struct ip_mreqn`结构体:
```c
struct ip_mreqn {
struct in_addr imr_multiaddr; // 组播IP
struct in_addr imr_address; // 本地IP
int imr_ifindex; // 网络接口索引
};

通信实现逻辑

广播服务器

  1. 创建DGRAM套接字
  2. 绑定广播地址或0.0.0.0
  3. 设置SO_REUSEADDR
  4. 循环接收数据

组播客户端

  1. 创建DGRAM套接字
  2. 加入组播组(IP_ADD_MEMBERSHIP)
  3. 绑定组播IP地址
  4. 接收群组消息

特殊处理机制

超时控制

  • 接收超时结构体:
    struct timeval {
    __kernel_time_t tv_sec; // 秒
    __kernel_suseconds_t tv_usec; // 微秒
    };

错误检测

  • 返回值检测:
    • recvfrom返回0表示空数据包
    • EAGAIN错误处理非阻塞状态
    • 发送失败重试机制

通信限制对比

特性单播广播组播
地址范围具体IP255结尾地址224-239网段
跨路由器支持不支持支持
适用场景精准传输局域网通知群组通信
资源消耗中等

代码结构示例

组播接收端

// 加入组播组
struct ip_mreqn mreq;
mreq.imr_multiaddr.s_addr = inet_addr("224.1.2.3");
mreq.imr_address.s_addr = inet_addr("192.168.1.100");
mreq.imr_ifindex = 0;
setsockopt(sockfd, IPPROTO_IP, IP_ADD_MEMBERSHIP, &mreq, sizeof(mreq));

广播发送端

// 启用广播权限
int broadcast = 1;
setsockopt(sockfd, SOL_SOCKET, SO_BROADCAST, &broadcast, sizeof(broadcast));

# 心跳包核心要点
## 基本概念
- **定义**:用于维持长连接的活跃状态,防止网络设备断开空闲连接
- **核心目的**:
- 检测客户端存活状态
- 避免防火墙/NAT误判连接失效
## 实现机制
### 时间戳维护
- **客户端**:发送业务消息或心跳包时更新最后通信时间
- **服务端**:
- 接收消息后更新时间戳
- 维护客户端列表(IP+Port+最后通信时间)
### 心跳包发送
- **周期触发**:客户端每30秒发送空数据包
- **信号机制**:
```c
signal(SIGALRM, handler); // 注册ALRM信号处理函数
alarm(5); // 每5秒触发信号

超时检测

  • 定时任务:服务端每秒检查时间差
  • 超时阈值:60秒无通信判定离线
  • 清理逻辑
    if(time(NULL) - tm > 4) {
    删除客户端记录
    }

关键函数

时间处理

  • time():获取1970年至今秒数
  • localtime():转换时间戳为tm结构体
  • strftime():格式化时间输出(如"%Y-%m-%d %H:%M:%S")

网络通信

  • recvfrom():接收UDP数据包
  • sendto():发送心跳包或业务数据

数据结构

消息类型

enum type_t { CHAR, HEART }; // CHAR=业务消息,HEART=心跳包

消息结构体

typedef struct msgbuf {
enum type_t type; // 消息类型
char text[128]; // 消息内容
} msgbuf_t;

客户端状态记录

typedef struct timebuf {
unsigned int ip; // 客户端IP
unsigned short port;// 端口号
time_t tm; // 最后通信时间
} timebuf_t;

代码结构

服务端逻辑

  1. 创建UDP套接字并绑定端口
  2. 启动独立线程检测超时客户端
  3. 接收消息后分类处理:
    • CHAR类型:更新通信时间并处理业务
    • HEART类型:仅更新时间戳

客户端逻辑

  1. 创建UDP套接字连接服务端
  2. 设置定时器发送心跳包:
    handler() {
    sendto(HEART包);
    alarm(5); // 重置5秒定时
    }

多线程处理

  • 超时检测线程
    pthread_create(&thread, NULL, cli_delete, NULL);
    pthread_detach(thread); // 分离线程
  • 清理逻辑
  • for循环遍历客户端列表,删除超时记录、

相关文章:

udp多点通信和心跳包

刷题 # UDP多点通信核心要点## 基础通信模式### 单播通信- 一对一通信方式- UDP默认通信模式- 地址指向具体目标主机### 广播通信- 一对多通信机制- 地址范围:xxx.xxx.xxx.255- 仅限局域网传输- 需设置SO_BROADCAST标志### 组播通信- 多对多群组通信- 地址范围&…...

什么是序列化与反序列化

序列化与反序列化:概念、作用及应用 一、基本定义 序列化(Serialization) 将 ** 对象的状态(数据、属性等)转换为可存储或传输的字节流(二进制或文本格式)** 的过程。 目的:使对象能…...

音视频学习:使用NDK编译FFmpeg动态库

1. 环境 1.1 基础配置 NDK 22b (r22b)FFmpeg 4.4Ubuntu 22.04 1.2 下载ffmpeg 官网提供了 .tar.xz 包,可以直接下载解压: wget https://ffmpeg.org/releases/ffmpeg-4.4.tar.xz tar -xvf ffmpeg-4.4.tar.xz cd ffmpeg-4.41.3 安装基础工具链 sudo …...

如何使用 Qwen3 实现 Agentic RAG?

今天,我们将学习如何部署由阿里巴巴最新Qwen 3驱动的Agentic RAG。 这里是我们的工具栈: CrewAI用于代理编排。 Firecrawl用于网络搜索。 LightningAI的LitServe用于部署。 顶部的视频展示了这一过程。 图表显示了我们的Agentic RAG流程&#xff1…...

相机、雷达标定工具,以及雷达自动标定的思路

本篇我们来看一下自动驾驶传感器配置一个非常重要的模块,也就是传感器的标定。这里主要是对我之前修改的功能包的使用进行一个介绍. 对应的资源也已经上传了,0积分下载 安装 首先整个项目是使用ros1来进行启动的,但是要想正常编译,需要先安装三个对应的…...

vsomeip环境搭建保姆级教程

vsomeip环境搭建保姆级教程 ubuntu环境搭建 {% links %} site: VMware搭建ubuntu保姆级教程 url: https://zhuanlan.zhihu.com/p/1903219373906327339 desc: flechazo image: https://q1.qlogo.cn/g?b=qq&nk=2861099&s=5 color: “#9d5b8b” {% endlinks %} vsomei…...

【工具记录分享】提取bilibili视频字幕

F12大法 教程很多 但方法比较统一 例快速提取视频字幕!适用B站、AI字幕等等。好用 - 哔哩哔哩 无脑小工具 哔哩哔哩B站字幕下载_在线字幕解析-飞鱼视频下载助手 把链接扔进去就会自动生成srt文件 需要txt可以配合: SRT转为TXT...

我的MCP相关配置记录

1.VSCode的Cline中的MCP {"mcpServers": {"github.com/modelcontextprotocol/servers/tree/main/src/github": {"autoApprove": [],"disabled": false,"timeout": 60,"command": "cmd","args&quo…...

systemd vs crontab:Linux 自动化运行系统的全面对比

在 Linux 系统运维和开发中,任务调度与服务管理 是不可或缺的一环。无论是定期备份、日志轮转,还是启动后台服务,自动化机制都能极大地提高系统的可靠性与效率。两种最常用的自动化工具是: crontab:传统的基于时间的任…...

我们来学nacos -- 集群nacos2.5.1mysql8.4

2.5.1集群搭建 架构下载解压到3个文件夹初始化数据库&数据迁移检查端口可用配置cluster.confapplication.properties 使用mysql8.4的jar启动db.num is null报错datasource错误成功 nginx反向代理集群查看 架构 其中包含3个nacos节点,然后一个负载均衡器代理3个…...

计算机网络核心技术解析:从基础架构到应用实践

计算机网络作为现代信息社会的基石,承载着全球数据交换与资源共享的核心功能。本文将从网络基础架构、核心协议、分层模型到实际应用场景,全面解析计算机网络的核心技术,并结合行业最新趋势,为读者构建系统的知识体系。 一、计算机…...

Spring Boot 基于 Cookie 实现单点登录:原理、实践与优化详解

前言 在多系统交互的应用场景中,单点登录(SSO)能够显著提升用户体验,减少重复登录的繁琐操作。基于 Cookie 的单点登录方案,凭借其简单直观、浏览器原生支持的特性,成为快速实现单点登录的有效方式。本文将…...

Rollup入门与进阶:为现代Web应用构建超小的打包文件

我们常常面临Webpack复杂配置或是Babel转译后的冗余代码,结果导致最终的包体积居高不下加载速度也变得异常缓慢,而在众多打包工具中Rollup作为一个轻量且高效的选择,正悄然改变着这一切,本文将带你深入了解这个令人惊艳的打包工具…...

pdf url 转 图片

背景&#xff1a;vue2.0需要把pdf转成图片&#xff0c;显示在url里面&#xff0c;使用pdfjs-dist来解决 步骤&#xff1a; 1、安装依赖包(我的项目是node12&#xff0c;安装太高版本会报错) npm i pdfjs-dist2.16.105 2、vue代码 <template><div class"main…...

专题四:综合练习( 找出所有子集的异或总和再求和)

以leetcode1863题为例 题目分析&#xff1a; 找到每个子集&#xff0c;然后子集中的元素异或之后全部相加 算法原理分析&#xff1a; 画决策树&#xff1a;第一层为这个子集有一个元素 第二层这个子集有两个元素 从上往下罗列&#xff0c;把所有子集都罗列出来&#xf…...

STM32 修炼手册

第一章 计算机体系结构(了解) 后续在板子上开发的时候&#xff0c;需要考虑是否有操作系统 方式一&#xff1a;有操作系统&#xff0c;通过c库通过os api操作硬件方式二&#xff1a;无操作系统&#xff0c; 通过c库通过固件库操作硬件 第二章 STM32开发板概述 板子/开发板&…...

缓存(2):数据一致性

概述 一致性就是数据保持一致,在分布式系统中,可以理解为多个节点中数据的值是一致的。 强一致性:这种一致性级别是最符合用户直觉的,它要求系统写入什么,读出来的也会是什么,用户体验好,但实现起来往往对系统的性能影响大弱一致性:这种一致性级别约束了系统在写入成功…...

什么是原码和补码

补码的本质确实是模运算&#xff08;Modular Arithmetic&#xff09;&#xff0c;这是理解补码为何能统一加减法的核心数学原理。下面用最通俗的语言和例子解释清楚&#xff1a; —### 1. 先理解什么是“模运算”- 模运算就是“周期性计数”&#xff0c;比如钟表&#xff1a; -…...

ppy/osu构建

下载 .NET (Linux、macOS 和 Windows) | .NET dotnet还行 构建&#xff1a;f5 运行&#xff1a;dotnet run --project osu.Desktop -c Debug...

基于几何布朗运动的股价预测模型构建与分析

基于几何布朗运动的股价预测模型构建与分析 摘要 本文建立基于几何布朗运动的股价预测模型&#xff0c;结合极大似然估计与蒙特卡洛模拟&#xff0c;推导股价条件概率密度函数并构建动态预测区间。实证分析显示模型在标普500指数预测中取得89%的覆盖概率&#xff0c;波动率估…...

使用交互式半自动化标注工具制作语义分割数据集

参考的初始资源&#xff1a; GitHub项目文档 B站视频 1.安装工具 打开Anaconda Prompt 1.创建虚拟环境 conda create -n isat_env python3.8 conda activate isat_env2.安装GPU版本pytorch 4070 Ti CUDN12.5 pip install torch torchvision torchaudio --index-url https:/…...

deepseek梳理java高级开发工程师微服务面试题

Java微服务高级面试题与答案 一、微服务架构设计 1. 服务拆分原则 Q1&#xff1a;微服务拆分时有哪些核心原则&#xff1f;如何解决拆分后的分布式事务问题&#xff1f; 答案&#xff1a; 服务拆分五大原则&#xff1a; 1. 单一职责原则&#xff08;SRP&#xff09;- 每个…...

二分查找算法的思路

二分查找思路总结 明确目标与单调性特点&#xff1a; 核心目标&#xff1a;寻找满足某种条件的答案&#xff08;如最小/最大值&#xff09;。单调性要求&#xff1a;需要证明你的判断函数具有单调性——即如果某个答案 T 可行&#xff0c;那么大于 T 的答案通常也是可行的&…...

(1)python开发经验

文章目录 1 安装包格式说明2 PySide支持Windows7 更多精彩内容&#x1f449;内容导航 &#x1f448;&#x1f449;Qt开发 &#x1f448;&#x1f449;python开发 &#x1f448; 1 安装包格式说明 PySide下载地址 进入下载地址后有多种安装包&#xff0c;怎么选择&#xff1a; …...

DAY05:深入解析生命周期与钩子函数

引言 在 Vue 开发中&#xff0c;生命周期和钩子函数是理解组件行为的关键。无论是初始化数据、操作 DOM&#xff0c;还是清理资源&#xff0c;生命周期钩子都提供了精确的控制点。本文将从基础理论出发&#xff0c;结合项目实战&#xff0c;详细剖析 Vue 3 的生命周期机制、组…...

python如何提取Chrome中的保存的网站登录用户名密码?

很多浏览器都贴心地提供了保存用户密码功能&#xff0c;用户一旦开启&#xff0c;就不需要每次都输入用户名、密码&#xff0c;非常方便。作为python脚本&#xff0c;能否拿到用户提前保存在浏览器中的用户名密码&#xff0c;用以自动登录呢&#xff1f;必须有&#xff0c;小爬…...

Redis实现分布式获取全局唯一自增ID的案例。

【1】简易自增版本(从 1 开始 1,2,3&#xff0c;...) 项目结构 下面是一个基于 RedisTemplate 实现的分布式全局唯一自增 ID 生成器的案例。适用于 Java Spring Boot 环境&#xff0c;利用 Redis 的原子操作 INCR 指令。 ✅ 原理说明 Redis 提供的 INCR 命令是原子性的&…...

人脸识别备案:筑牢人脸信息 “安全墙”

人脸识别备案制度主要依据《人脸识别技术应用安全管理办法》建立&#xff0c;人脸识别技术广泛应用于安防、金融、门禁、交通等领域&#xff0c;带来便利高效的同时&#xff0c;人脸信息安全问题也引发担忧。为规范技术应用、保护个人信息权益&#xff0c;人脸识别备案制度应运…...

基于RT-Thread的STM32F4开发第三讲——DAC

文章目录 前言一、DAC是什么&#xff1f;二、RT-Thread工程创建三、DAC函数编写1.DAC.c2.DAC.h3.main.c 四、结果测试五、工程分享 前言 本章利用RT-Thread最新的驱动5.1.0开发DAC模块&#xff0c;使用的开发板是正点原子的STM32F4探索者。很多配置和上文重复&#xff0c;本文…...

UE5通过C++实现TcpSocket连接

在 Unreal Engine 5 的 C 项目中&#xff0c;实现一个具备消息监听、心跳检测和断线重连功能的 TCP 客户端&#xff0c;可以参考以下完整示例。 准备工作 1、模块依赖 在 YourModule.Build.cs 文件中&#xff0c;添加对 Sockets 和 Networking 模块的依赖&#xff1a; Publ…...