从源码编译安装Fast-DDS,跑HelloFish例程时遇到的问题与解决方法

本文详细描述了作者在遵循鱼香ROS教程搭建Fast-DDS过程中遇到的问题,包括工具版本更新、配置顺序调整、链接替换等,旨在帮助读者解决安装过程中的难题。
摘要由CSDN通过智能技术生成

源码编译安装 Fast-DDS

我在跟着鱼香ROS教程搭建Fast-DDS和跑HelloFish例程时碰到了不少问题,在跑通并整理后,我把我修改后的配置过程分享给大家,希望可以帮大家节省一些时间。
鱼香ROS Fast-DDS环境搭建 原文
主要做了以下修改:

  1. 修改了一些工具的版本;
  2. 调整了配置的顺序;
  3. 替换了一些链接;
  4. 跑HelloFish例程时遇到的一些问题与我的解决方法;

安装工具和依赖库

修改了jdk版本

sudo apt-get install -y python3-colcon-common-extensions python3-vcstool zip openjdk-11-jdk
sudo apt-get install -y libasio-dev

创建目录, 下载仓库

创建目录

mkdir -p fastdds_ws/src && cd fastdds_ws

下载并配置gradle

这里修改了gradle的链接
注意:xxx处修改为fastdds_ws所在路径

wget https://services.gradle.org/distributions/gradle-6.4-bin.zip && unzip gradle-6.4-bin.zip
echo 'export PATH=$PATH:xxx/fastdds_ws/gradle-6.4/bin/' >> ~/.bashrc && source ~/.bashrc

创建fastrtps.repos文件

touch fastrtps.repos

将下面内容复制到fastrtps.repos文件中

repositories:
    foonathan_memory_vendor:
        type: git
        url: https://kkgithub.com/eProsima/foonathan_memory_vendor.git
        version: master
    fastcdr:
        type: git
        url: https://kkgithub.com/eProsima/Fast-CDR.git
        version: master
    fastrtps:
        type: git
        url: https://kkgithub.com/eProsima/Fast-DDS.git
        version: master
    fastddsgen:
        type: git
        url: https://kkgithub.com/eProsima/Fast-DDS-Gen.git
        version: master
    fastddsgen/thirdparty/idl-parser:
        type: git
        url: https://kkgithub.com/eProsima/IDL-Parser.git
        version: master

运行命令

vcs import src < fastrtps.repos

编译

colcon build
cd src/fastddsgen/ &&  gradle assemble

配置环境变量

注意:xxx处修改为fastdds_ws所在路径

echo 'source xxx/fastdds_ws/install/setup.bash' >> ~/.bashrc
echo 'export PATH=$PATH:xxx/fastdds_ws/src/fastddsgen/scripts' >> ~/.bashrc
source ~/.bashrc

在跑HelloFish例程时遇到的一些问题

git的代理问题

取消git代理设置

git config --global --unset http.proxy
git config --global --unset https.proxy

无法从github拉取代码

使用镜像源

git clone https://kkgithub.com/fishros/dds_tutorial.git

CMake 版本问题

直接根据报错位置修改成你安装的CMake版本,我编译通过后运行没有出现问题

ids与Fast-DDS版本不对应

使用下面命令重新生成代码,把生成的代码复制到idl_generate目录下

fastddsgen -example CMake HelloFishRos.idl

–examle 后的参数根据你的系统修改
使用你的 HelloFishRos.idl 文件路径替换 HelloFishRos.idl。

没有引入 thread 和 chrono

在发布者与订阅者源代码文件中添加

#include <chrono>
#include <thread>
  • 14
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
### 回答1: Fast-DDS是一个高性能的、基于数据发布-订阅模型的通信协议。它提供了丰富的QoS(服务质量)策略以及灵活的路由机制,以满足不同场景下的通信需求。 其中,QoS策略是指在数据传输的过程中,可以通过一定的配置方式来控制数据传输的质量、可靠性、延时等因素。Fast-DDS中提供了多种QoS策略,包括消息传输的可靠性、数据的存储方式、订阅者优先级等。 在Fast-DDS中,消息传输的可靠性可以通过以下几种QoS策略来控制: 1. RELIABILITY,即可靠性:用于控制消息的可靠性,包括发布者和订阅者之间的ack确认机制,以及网络连接中的重传机制。 2. DURABILITY,即持久性:用于控制消息的持久化方式,包括将消息写入本地磁盘或将消息存储在内存中。 3. HISTORY,即历史消息:用于控制订阅者在订阅之前是否可以获取历史消息,以及历史消息保存的方式(内存中、磁盘中、或通过文件传输)。 除了上述QoS策略,Fast-DDS还提供了很多其他的QoS选项,如数据传输的优先级、最大传输延迟、数据分发的方式等等,以满足不同的通信场景需求。 总体而言,Fast-DDS的QoS策略提供了丰富的选项和灵活的配置方式,能够帮助开发人员实现高性能、可靠的数据传输。 ### 回答2: Fast-DDS是一种高性能的DDS实现,可以用于构建实时和分布式系统。Fast-DDS支持多种QoS策略,这些策略允许用户在系统性能和资利用率之间做出权衡。以下是Fast-DDS的QoS策略的几个关键点: 1. 可靠性:Fast-DDS支持可靠和非可靠的通信,通过配置可靠性参数,可以控制数据重传和丢失时间等方面的行为。 2. 带宽控制:Fast-DDS支持带宽限制,通过配置带宽参数,可以限制系统的带宽使用,从而避免因过度使用带宽导致的卡顿和延迟。 3. 时间同步:Fast-DDS支持时间同步,通过配置时间同步参数,可以在系统中确立一个统一的时间基准,从而避免因时间差异而导致的不一致性。 4. 优先级:Fast-DDS支持消息优先级,通过配置优先级参数,可以确保重要消息的优先传输,从而提高系统的响应能力。 5. QoS Inheritance: Fast-DDS支持QoS继承,它允许用户在不同级别的实体之间继承QoS属性。如,可将主题级别的QoS继承到订阅者级别,从而确保所有订阅者都使用同一的QoS策略。 综上所述,Fast-DDS的QoS策略提供了一些非常有用的功能,可以帮助用户在不同的反应性和资利用率需求之间做出权衡,从而优化系统的性能和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值