专业解析 .bashrc 中 ROS 工作空间的加载顺序及其影响 ubuntu 机器人
专业解析 .bashrc
中 ROS 工作空间的加载顺序及其影响
在使用 ROS(Robot Operating System)进行开发时,通常会涉及多个 Catkin 工作空间(Catkin Workspace)。这些工作空间包含不同的 ROS 包和节点,可能相互依赖或存在版本差异。正确配置和加载这些工作空间对于确保 ROS 包的正确识别和功能的正常运行至关重要。本文将详细解释 .bashrc
文件中工作空间加载顺序的重要性,分析其对环境变量特别是 ROS_PACKAGE_PATH
的影响,并通过示例说明如何合理配置加载顺序以避免常见问题。
一、背景概述
1. ROS 工作空间(Catkin Workspace)
Catkin 是 ROS 的官方构建系统,用于组织和编译 ROS 包。一个 Catkin 工作空间通常包含以下目录结构:
~/catkin_ws/
├── src/
│ ├── package_1/
│ ├── package_2/
│ └── ...
├── build/
└── devel/
- src/:包含所有 ROS 包的源代码。
- build/:CMake 构建文件生成目录。
- devel/:编译后生成的开发环境,包含环境配置脚本
setup.bash
。
2. .bashrc
文件
.bashrc
是 Bash Shell 的配置文件,每次启动新的终端会话时都会执行。通过在 .bashrc
中添加 source
命令,可以自动加载 ROS 环境和多个工作空间的配置,从而简化开发流程。
二、工作空间加载顺序的重要性
1. setup.bash
的作用
每个 Catkin 工作空间的 devel/setup.bash
文件负责设置环境变量,尤其是 ROS_PACKAGE_PATH
,以便 ROS 工具能够找到和使用该工作空间中的包。执行 source devel/setup.bash
会将该工作空间的路径优先级提升,使其包含的包在 ROS 系统中具有更高的优先级。
2. 多工作空间叠加(Overlay Workspaces)
当存在多个工作空间时,后加载的工作空间会覆盖先前加载的工作空间中相同名称的包。这意味着加载顺序直接影响 ROS 包的解析和优先级。例如,如果两个工作空间都包含 cv_bridge
包,最后加载的工作空间中的 cv_bridge
将被 ROS 系统优先识别。
3. 环境变量的累积和覆盖
ROS_PACKAGE_PATH
:包含所有 ROS 包的搜索路径,顺序决定了包的优先级。后添加的路径优先级更高。PATH
、LD_LIBRARY_PATH
、PKG_CONFIG_PATH
等:这些环境变量也会受到加载顺序的影响,可能导致库和可执行文件的冲突或版本不兼容。
三、常见问题分析
1. rospack find cv_bridge
无法找到包
用户在 .bashrc
中加载多个工作空间时,特别是将 source ~/pointcloudmap_ws/devel/setup.bash
放在最后,会导致 rospack find cv_bridge
无法找到 cv_bridge
包。这通常是因为:
- 加载顺序问题:后加载的工作空间可能缺少
cv_bridge
包,或包含不同版本,覆盖了前面工作空间中的配置。 - 错误的
ROS_PACKAGE_PATH
设置:手动添加路径时添加了包本身而非其父目录,导致 ROS 无法正确解析。
2. 环境变量冲突
加载多个工作空间时,若不同工作空间中存在相同名称的包或依赖不同版本的库(如 OpenCV),可能导致编译或运行时错误。
四、详细解决方案
1. 正确设置 ROS_PACKAGE_PATH
确保 ROS_PACKAGE_PATH
包含的是 ROS 包的父目录,而不是包本身的路径。例如:
- 错误设置:
export ROS_PACKAGE_PATH=$ROS_PACKAGE_PATH:~/vision_opencv/cv_bridge
- 正确设置:
export ROS_PACKAGE_PATH=$ROS_PACKAGE_PATH:~/vision_opencv
示例解释:
假设 cv_bridge
位于 ~/vision_opencv/cv_bridge
,则应将 ~/vision_opencv
添加到 ROS_PACKAGE_PATH
,使 ROS 能在该目录下查找所有包。
2. 优化 .bashrc
中的工作空间加载顺序
加载多个工作空间时,建议将包含关键依赖包(如 cv_bridge
)的工作空间放在最前面,其他工作空间按优先级递减的顺序加载。这样,关键包的版本优先级最高,避免被后加载的工作空间覆盖。
示例 .bashrc
配置:
# >>> conda initialize >>>
# !! Contents within this block are managed by 'conda init' !!
__conda_setup="$('/home/lyb/anaconda3/bin/conda' 'shell.bash' 'hook' 2> /dev/null)"
if [ $? -eq 0 ]; theneval "$__conda_setup"
elseif [ -f "/home/lyb/anaconda3/etc/profile.d/conda.sh" ]; then. "/home/lyb/anaconda3/etc/profile.d/conda.sh"elseexport PATH="/home/lyb/anaconda3/bin:$PATH"fi
fi
unset __conda_setup
# <<< conda initialize <<<export JAVA_HOME=/usr/lib/jvm/default-java/jre# OpenCV 3.2.0 环境变量设置
export PATH=/usr/local/opencv3.2.0/bin:$PATH
export LD_LIBRARY_PATH=/usr/local/opencv3.2.0/lib:$LD_LIBRARY_PATH
export PKG_CONFIG_PATH=/usr/local/opencv3.2.0/lib/pkgconfig:$PKG_CONFIG_PATH# ROS 环境配置
source /opt/ros/noetic/setup.bash# 加载关键工作空间(包含 cv_bridge 的工作空间)
source ~/catkin_ws/devel/setup.bash# 加载其他工作空间,顺序从高优先级到低优先级
source ~/AutoPaintRobot/devel/setup.bash
source ~/demo_ros-control_ws/devel/setup.bash
source ~/ros_web/devel/setup.bash
source ~/ROS-Noetic-pr2/catkin_ws/devel/setup.bash
source ~/catkin_ws_1/devel/setup.bash
source ~/Orbbec_ws/devel/setup.bash
source ~/pointcloudmap_ws/devel/setup.bash# 添加 GCC 工具链和 Python 路径
export PATH=/home/lyb/gcc-arm-none-eabi-5_4-2016q2/bin:$PATH
export PATH=/usr/local/python3.10.14/bin:$PATH# 设置别名和其他环境变量
alias python='python3'# 添加 ROS 库路径
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/opt/ros/noetic/lib/pkgconfig
示例解释:
-
加载 ROS 基础环境:
source /opt/ros/noetic/setup.bash
这是 ROS Noetic 的全局配置,必须首先加载。
-
加载关键工作空间:
source ~/catkin_ws/devel/setup.bash
假设
~/catkin_ws
包含cv_bridge
,将其放在最前面,确保其包在ROS_PACKAGE_PATH
中优先级最高。 -
加载其他工作空间:
source ~/AutoPaintRobot/devel/setup.bash source ~/demo_ros-control_ws/devel/setup.bash ...
按照使用频率或依赖关系,从高优先级到低优先级依次加载。
-
环境变量设置:
export PATH=/usr/local/opencv3.2.0/bin:$PATH export LD_LIBRARY_PATH=/usr/local/opencv3.2.0/lib:$LD_LIBRARY_PATH export PKG_CONFIG_PATH=/usr/local/opencv3.2.0/lib/pkgconfig:$PKG_CONFIG_PATH
确保自定义库路径优先于系统默认路径,避免版本冲突。
3. 避免手动设置 ROS_PACKAGE_PATH
依赖于 Catkin 工作空间的 setup.bash
自动管理 ROS_PACKAGE_PATH
,避免手动干预,以减少配置冲突。若确实需要手动添加路径,确保添加的是包的父目录。
错误示例:
export ROS_PACKAGE_PATH=$ROS_PACKAGE_PATH:~/vision_opencv/cv_bridge
正确示例:
export ROS_PACKAGE_PATH=$ROS_PACKAGE_PATH:~/vision_opencv
4. 使用工作空间叠加(Overlay Workspaces)
Catkin 支持叠加多个工作空间,后加载的工作空间可以覆盖前加载的工作空间中的包。确保加载顺序符合优先级需求。
示例:
假设有两个工作空间:
~/catkin_ws
:包含核心包,如cv_bridge
~/pointcloudmap_ws
:包含自定义包,可能依赖cv_bridge
加载顺序:
~/catkin_ws
:核心包优先加载~/pointcloudmap_ws
:自定义包加载,依赖于核心包
source ~/catkin_ws/devel/setup.bash
source ~/pointcloudmap_ws/devel/setup.bash
5. 示例 .bashrc
配置与解释
完整示例:
# >>> conda initialize >>>
# !! Contents within this block are managed by 'conda init' !!
__conda_setup="$('/home/lyb/anaconda3/bin/conda' 'shell.bash' 'hook' 2> /dev/null)"
if [ $? -eq 0 ]; theneval "$__conda_setup"
elseif [ -f "/home/lyb/anaconda3/etc/profile.d/conda.sh" ]; then. "/home/lyb/anaconda3/etc/profile.d/conda.sh"elseexport PATH="/home/lyb/anaconda3/bin:$PATH"fi
fi
unset __conda_setup
# <<< conda initialize <<<export JAVA_HOME=/usr/lib/jvm/default-java/jre# OpenCV 3.2.0 环境变量设置
export PATH=/usr/local/opencv3.2.0/bin:$PATH
export LD_LIBRARY_PATH=/usr/local/opencv3.2.0/lib:$LD_LIBRARY_PATH
export PKG_CONFIG_PATH=/usr/local/opencv3.2.0/lib/pkgconfig:$PKG_CONFIG_PATH# ROS 基础环境配置
source /opt/ros/noetic/setup.bash# 加载包含关键依赖包的工作空间
source ~/catkin_ws/devel/setup.bash# 加载其他工作空间,按优先级递减顺序
source ~/AutoPaintRobot/devel/setup.bash
source ~/demo_ros-control_ws/devel/setup.bash
source ~/ros_web/devel/setup.bash
source ~/ROS-Noetic-pr2/catkin_ws/devel/setup.bash
source ~/catkin_ws_1/devel/setup.bash
source ~/Orbbec_ws/devel/setup.bash
source ~/pointcloudmap_ws/devel/setup.bash# 添加 GCC 工具链和 Python 路径
export PATH=/home/lyb/gcc-arm-none-eabi-5_4-2016q2/bin:$PATH
export PATH=/usr/local/python3.10.14/bin:$PATH# 设置别名和其他环境变量
alias python='python3'# 添加 ROS 库路径
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/opt/ros/noetic/lib/pkgconfig# 确保 `cv_bridge` 的父目录已在 ROS_PACKAGE_PATH 中
export ROS_PACKAGE_PATH=$ROS_PACKAGE_PATH:~/vision_opencv
示例解释:
-
Conda 初始化:
- 保持 Conda 环境的正确加载,不影响 ROS 环境配置。
-
JAVA_HOME 设置:
- 设置 Java 环境变量,供需要 Java 的工具使用。
-
OpenCV 3.2.0 环境变量设置:
- 手动指定 OpenCV 3.2.0 的路径,确保使用特定版本的 OpenCV。
- 注意:若 ROS Noetic 默认使用 OpenCV 4,需谨慎管理版本冲突。
-
加载 ROS 基础环境:
source /opt/ros/noetic/setup.bash
:加载 ROS Noetic 的全局配置。
-
加载关键工作空间:
source ~/catkin_ws/devel/setup.bash
:包含核心依赖包,如cv_bridge
,优先加载以确保其包优先级最高。
-
加载其他工作空间:
- 按优先级递减顺序加载其他工作空间,避免覆盖关键依赖包。
-
添加工具链和 Python 路径:
- 将自定义工具链和 Python 版本添加到
PATH
,确保使用特定版本。
- 将自定义工具链和 Python 版本添加到
-
设置别名和其他环境变量:
- 设置
python
别名为python3
,确保脚本使用正确的 Python 版本。
- 设置
-
添加 ROS 库路径:
- 确保 ROS 库路径正确添加,避免库文件冲突。
-
确保
ROS_PACKAGE_PATH
正确:- 添加
~/vision_opencv
,使 ROS 能正确查找cv_bridge
包。
- 添加
6. 验证配置
在修改 .bashrc
后,执行以下命令以使更改生效:
source ~/.bashrc
然后,验证 cv_bridge
是否可被识别:
rospack find cv_bridge
若返回正确的路径(例如 /home/lyb/catkin_ws/src/vision_opencv/cv_bridge
),说明配置正确。
五、总结与最佳实践
1. 加载顺序策略
- 核心工作空间优先:包含关键依赖包(如
cv_bridge
)的工作空间应最先加载,确保其包在ROS_PACKAGE_PATH
中优先级最高。 - 叠加工作空间:后加载的工作空间在叠加时覆盖前加载的工作空间中的同名包,应根据需要安排加载顺序。
2. 环境变量管理
- 避免手动修改
ROS_PACKAGE_PATH
:依赖setup.bash
自动管理,减少人为错误。 - 处理库版本冲突:尽量使用 ROS 默认的库版本,避免手动指定不同版本的库,除非必要。
- 统一使用
catkin
构建系统:避免混用过时的rosbuild
构建系统,以减少依赖识别问题。
3. 工作空间维护
- 保持工作空间整洁:定期清理不必要的包和依赖,减少潜在冲突。
- 版本控制:使用 Git 等版本控制系统管理工作空间,方便回滚和协作。
- 文档记录:记录各工作空间的用途、依赖和配置,便于维护和问题排查。
4. 参考资源
- ROS 官方文档:Catkin Workspace
- 社区支持:ROS Answers
- 最佳实践指南:ROS Wiki - Best Practices
通过遵循上述指南和最佳实践,您可以有效管理多个 ROS 工作空间,避免常见的环境配置问题,确保 ROS 包的正确识别和功能的稳定运行。
相关文章:
专业解析 .bashrc 中 ROS 工作空间的加载顺序及其影响 ubuntu 机器人
专业解析 .bashrc 中 ROS 工作空间的加载顺序及其影响 在使用 ROS(Robot Operating System)进行开发时,通常会涉及多个 Catkin 工作空间(Catkin Workspace)。这些工作空间包含不同的 ROS 包和节点,可能相互…...

Apache Doris 现行版本 Docker-Compose 运行教程
特别注意!Doris On Docker 部署方式仅限于开发环境或者功能测试环境,不建议生产环境部署! 如有生产环境或性能测试集群部署诉求,请使用裸机/虚机部署或K8S Operator部署方案! 原文阅读:Apache Doris 现行版…...

Flink四大基石之窗口(Window)使用详解
目录 一、引言 二、为什么需要 Window 三、Window 的控制属性 窗口的长度(大小) 窗口的间隔 四、Flink 窗口应用代码结构 是否分组 Keyed Window --键控窗 Non-Keyed Window 核心操作流程 五、Window 的生命周期 分配阶段 触发计算 六、Wi…...

NGINX配置https双向认证(自签一级证书)
一 生成自签证书 以下是生成自签证书(包括服务端和客户端的证书)的步骤,以下命令执行两次,分别生成客户端和服务端证书和私钥。具体执行可以先建两个目录client和server,分别进入到这两个目录下执行下面的命令。 生成私钥: 首先&…...

Flink双流Join
在离线 Hive 中,我们经常会使用 Join 进行多表关联。那么在实时中我们应该如何实现两条流的 Join 呢?Flink DataStream API 为我们提供了3个算子来实现双流 join,分别是: join coGroup intervalJoin 下面我们分别详细看一下这…...

【数据结构实战篇】用C语言实现你的私有队列
🏝️专栏:【数据结构实战篇】 🌅主页:f狐o狸x 在前面的文章中我们用C语言实现了栈的数据结构,本期内容我们将实现队列的数据结构 一、队列的概念 队列:只允许在一端进行插入数据操作,在另一端…...

基于web的海贼王动漫介绍 html+css静态网页设计6页+设计文档
📂文章目录 一、📔网站题目 二、✍️网站描述 三、📚网站介绍 四、🌐网站演示 五、⚙️网站代码 🧱HTML结构代码 💒CSS样式代码 六、🔧完整源码下载 七、📣更多 一、&#…...
2022 年 9 月青少年软编等考 C 语言三级真题解析
目录 T1. 课程冲突T2. 42 点思路分析T3. 最长下坡思路分析T4. 吃糖果思路分析T5. 放苹果思路分析T1. 课程冲突 此题为 2021 年 9 月三级第一题原题,见 2021 年 9 月青少年软编等考 C 语言三级真题解析中的 T1。 T2. 42 点 42 42 42 是: 组合数学上的第 5 5 5 个卡特兰数字…...

机器学习算法(六)---逻辑回归
常见的十大机器学习算法: 机器学习算法(一)—决策树 机器学习算法(二)—支持向量机SVM 机器学习算法(三)—K近邻 机器学习算法(四)—集成算法 机器学习算法(五…...
计算机科学中的主要协议
1、主要应用层协议: HTTP、FTP、SMTP、POP、IMAP、DNS、TELNET和SSH等 应用层协议的主要功能是支持网络应用,定义了不同应用程序之间的通信规则。它们负责将用户操作转换为网络可以理解的数据格式,并通过传输层进行传输。应用层协议直接与用…...

下载maven 3.6.3并校验文件做md5或SHA512校验
一、下载Apache Maven 3.6.3 Apache Maven 3.6.3 官方下载链接: 二进制压缩包(推荐): ZIP格式: https://archive.apache.org/dist/maven/maven-3/3.6.3/binaries/apache-maven-3.6.3-bin.zipTAR.GZ格式: https://archive.apache.org/dist/…...

【Android】View工作原理
View 是Android在视觉上的呈现在界面上Android提供了一套GUI库,里面有很多控件,但是很多时候我们并不满足于系统提供的控件,因为这样就意味这应用界面的同类化比较严重。那么怎么才能做出与众不同的效果呢?答案是自定义View&#…...
TIE算法具体求解-为什么是泊松方程和傅里叶变换
二维泊松方程的通俗理解 二维泊松方程 是偏微分方程的一种形式,通常用于描述空间中某个标量场(如位相场、电势场)的分布规律。其一般形式为: ∇ 2 ϕ ( x , y ) f ( x , y ) \nabla^2 \phi(x, y) f(x, y) ∇2ϕ(x,y)f(x,y) 其…...
postman中获取随机数、唯一ID、时间日期(包括当前日期增减)截取指定位数的字符等
在Postman中,您可以使用内置的动态变量和编写脚本的方式来获取随机数、唯一ID、时间日期以及截取指定位数的字符。以下是具体的操作方法: 一、postman中获取随机数、唯一ID、时间日期(包括当前日期增减)截取指定位数的字符等 获取…...

【计算机网络】实验3:集线器和交换器的区别及交换器的自学习算法
实验 3:集线器和交换器的区别及交换器的自学习算法 一、 实验目的 加深对集线器和交换器的区别的理解。 了解交换器的自学习算法。 二、 实验环境 • Cisco Packet Tracer 模拟器 三、 实验内容 1、熟悉集线器和交换器的区别 (1) 第一步:构建网络…...

flink学习(14)—— 双流join
概述 Join:内连接 CoGroup:内连接,左连接,右连接 Interval Join:点对面 Join 1、Join 将有相同 Key 并且位于同一窗口中的两条流的元素进行关联。 2、Join 可以支持处理时间(processing time)和事件时…...

HTTP协议详解:从HTTP/1.0到HTTP/3的演变与优化
深入浅出:从头到尾全面解析HTTP协议 一、HTTP协议概述 1.1 HTTP协议简介 HTTP(HyperText Transfer Protocol,超文本传输协议)是互联网上应用最广泛的通信协议之一。它用于客户端与服务器之间的数据传输,尤其是在Web…...
张量并行和流水线并行在Transformer中的具体部位
目录 张量并行和流水线并行在Transformer中的具体部位 一、张量并行 二、流水线并行 张量并行和流水线并行在Transformer中的具体部位 张量并行和流水线并行是Transformer模型中用于提高训练效率的两种并行策略。它们分别作用于模型的不同部位,以下是对这两种并行的具体说…...

WEB开发: 丢掉包袱,拥抱ASP.NET CORE!
今天的 Web 开发可以说进入了一个全新的时代,前后端分离、云原生、微服务等等一系列现代技术架构应运而生。在这个背景下,作为开发者,你一定希望找到一个高效、灵活、易于扩展且具有良好性能的框架。那么,ASP.NET Core 显然是一个…...

【论文阅读】Federated learning backdoor attack detection with persistence diagram
目的:检测联邦学习环境下,上传上来的模型是不是恶意的。 1、将一个模型转换为|L|个PD,(其中|L|为层数) 如何将每一层转换成一个PD? 为了评估第𝑗层的激活值,我们需要𝑐个输入来获…...
Objective-C常用命名规范总结
【OC】常用命名规范总结 文章目录 【OC】常用命名规范总结1.类名(Class Name)2.协议名(Protocol Name)3.方法名(Method Name)4.属性名(Property Name)5.局部变量/实例变量(Local / Instance Variables&…...
生成 Git SSH 证书
🔑 1. 生成 SSH 密钥对 在终端(Windows 使用 Git Bash,Mac/Linux 使用 Terminal)执行命令: ssh-keygen -t rsa -b 4096 -C "your_emailexample.com" 参数说明: -t rsa&#x…...

Module Federation 和 Native Federation 的比较
前言 Module Federation 是 Webpack 5 引入的微前端架构方案,允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...
Linux系统部署KES
1、安装准备 1.版本说明V008R006C009B0014 V008:是version产品的大版本。 R006:是release产品特性版本。 C009:是通用版 B0014:是build开发过程中的构建版本2.硬件要求 #安全版和企业版 内存:1GB 以上 硬盘…...

【C++】纯虚函数类外可以写实现吗?
1. 答案 先说答案,可以。 2.代码测试 .h头文件 #include <iostream> #include <string>// 抽象基类 class AbstractBase { public:AbstractBase() default;virtual ~AbstractBase() default; // 默认析构函数public:virtual int PureVirtualFunct…...

AD学习(3)
1 PCB封装元素组成及简单的PCB封装创建 封装的组成部分: (1)PCB焊盘:表层的铜 ,top层的铜 (2)管脚序号:用来关联原理图中的管脚的序号,原理图的序号需要和PCB封装一一…...

PydanticAI快速入门示例
参考链接:https://ai.pydantic.dev/#why-use-pydanticai 示例代码 from pydantic_ai import Agent from pydantic_ai.models.openai import OpenAIModel from pydantic_ai.providers.openai import OpenAIProvider# 配置使用阿里云通义千问模型 model OpenAIMode…...

【PX4飞控】mavros gps相关话题分析,经纬度海拔获取方法,卫星数锁定状态获取方法
使用 ROS1-Noetic 和 mavros v1.20.1, 携带经纬度海拔的话题主要有三个: /mavros/global_position/raw/fix/mavros/gpsstatus/gps1/raw/mavros/global_position/global 查看 mavros 源码,来分析他们的发布过程。发现前两个话题都对应了同一…...
Yii2项目自动向GitLab上报Bug
Yii2 项目自动上报Bug 原理 yii2在程序报错时, 会执行指定action, 通过重写ErrorAction, 实现Bug自动提交至GitLab的issue 步骤 配置SiteController中的actions方法 public function actions(){return [error > [class > app\helpers\web\ErrorAction,],];}重写Error…...

使用python进行图像处理—图像变换(6)
图像变换是指改变图像的几何形状或空间位置的操作。常见的几何变换包括平移、旋转、缩放、剪切(shear)以及更复杂的仿射变换和透视变换。这些变换在图像配准、图像校正、创建特效等场景中非常有用。 6.1仿射变换(Affine Transformation) 仿射变换是一种…...