linux中can,pcap数据录制与udp缓存空间配置

1.简单粗暴的数据录制

录制点云数据:

clike 复制代码
sudo tcpdump -i ens33 -w /home/cyun/my_lidar.pcap udp port 6699 or udp port 7788

录制can报文:

clike 复制代码
candump -l can2
clike 复制代码
canplayer -I candump-2023-xx-xx_xxxxxx.log
clike 复制代码
# 格式: canplayer -I <文件> 录制时can=现在想要的输出的can口
canplayer -I my_drive_data.log i can2=can0

2.创建虚拟can口与can消息的发布

clike 复制代码
# 1. 加载虚拟CAN模块
sudo modprobe vcan

# 2. 创建一个叫 can2 的虚拟接口 (名字必须和你 python 代码里的一致!)
sudo ip link add dev can2 type vcan

# 3. 启动接口
sudo ip link set up can2

发送测试

clike 复制代码
# -g 10: 间隔10ms发一次
# -I 32A: 指定发送 ID 为 32A (即810)
# -D r: 数据内容随机
cangen can2 -g 10 -I 32A -D r

3.通信频率与缓存空间

rslidar(以及绝大多数激光雷达)使用的是 UDP 协议 进行大量数据的传输。

这个问题一般就是ros2 topic hz 打印出来的频率是非常低的(大概是6-7hz的样子)

如果发现频率问题,那就一定是这个缓存空间不够的问题了,我们需要设置一下linux的默认缓存空间(注意:这里有个误区,千万不要去配置dds的yaml给ros2!!!)

clike 复制代码
sudo gedit /etc/sysctl.d/10-cyclone-max.conf
clike 复制代码
# ------------- 雷达 UDP 缓冲区优化 -------------
# UDP 接收缓冲区(读缓冲区,工控机收雷达数据)
net.core.rmem_default = 26214400  # 默认 25MB
net.core.rmem_max = 67108864      # 最大 64MB

# UDP 发送缓冲区(写缓冲区,DDS 发点云数据)
net.core.wmem_default = 26214400  # 默认 25MB
net.core.wmem_max = 67108864      # 最大 64MB

使设置生效:

clike 复制代码
sudo sysctl -p /etc/sysctl.d/10-cyclone-max.conf

关机之后再次开机,然后查看设置是否保留了下来:

复制代码
# 默认接收缓冲区大小(全局)
sysctl net.core.rmem_default

# 最大接收缓冲区大小(全局上限)
sysctl net.core.rmem_max

# 默认发送缓冲区大小(全局)
sysctl net.core.wmem_default

# 最大发送缓冲区大小(全局上限)
sysctl net.core.wmem_max

结果如下所示

相关推荐
chlk1231 天前
Linux文件权限完全图解:读懂 ls -l 和 chmod 755 背后的秘密
linux·操作系统
舒一笑1 天前
Ubuntu系统安装CodeX出现问题
linux·后端
改一下配置文件1 天前
Ubuntu24.04安装NVIDIA驱动完整指南(含Secure Boot解决方案)
linux
碳基沙盒1 天前
OpenClaw 多 Agent 配置实战指南
运维
深紫色的三北六号1 天前
Linux 服务器磁盘扩容与目录迁移:rsync + bind mount 实现服务无感迁移(无需修改配置)
linux·扩容·服务迁移
SudosuBash2 天前
[CS:APP 3e] 关于对 第 12 章 读/写者的一点思考和题解 (作业 12.19,12.20,12.21)
linux·并发·操作系统(os)
哈基咪怎么可能是AI2 天前
为什么我就想要「线性历史 + Signed Commits」GitHub 却把我当猴耍 🤬🎙️
linux·github
十日十行3 天前
Linux和window共享文件夹
linux
木心月转码ing3 天前
WSL+Cpp开发环境配置
linux
蝎子莱莱爱打怪4 天前
Centos7中一键安装K8s集群以及Rancher安装记录
运维·后端·kubernetes