专业解析 .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? 为了评估第𝑗层的激活值,我们需要𝑐个输入来获…...
eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)
说明: 想象一下,你正在用eNSP搭建一个虚拟的网络世界,里面有虚拟的路由器、交换机、电脑(PC)等等。这些设备都在你的电脑里面“运行”,它们之间可以互相通信,就像一个封闭的小王国。 但是&#…...
docker详细操作--未完待续
docker介绍 docker官网: Docker:加速容器应用程序开发 harbor官网:Harbor - Harbor 中文 使用docker加速器: Docker镜像极速下载服务 - 毫秒镜像 是什么 Docker 是一种开源的容器化平台,用于将应用程序及其依赖项(如库、运行时环…...
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以?
Golang 面试经典题:map 的 key 可以是什么类型?哪些不可以? 在 Golang 的面试中,map 类型的使用是一个常见的考点,其中对 key 类型的合法性 是一道常被提及的基础却很容易被忽视的问题。本文将带你深入理解 Golang 中…...
PHP和Node.js哪个更爽?
先说结论,rust完胜。 php:laravel,swoole,webman,最开始在苏宁的时候写了几年php,当时觉得php真的是世界上最好的语言,因为当初活在舒适圈里,不愿意跳出来,就好比当初活在…...
测试markdown--肇兴
day1: 1、去程:7:04 --11:32高铁 高铁右转上售票大厅2楼,穿过候车厅下一楼,上大巴车 ¥10/人 **2、到达:**12点多到达寨子,买门票,美团/抖音:¥78人 3、中饭&a…...
使用 SymPy 进行向量和矩阵的高级操作
在科学计算和工程领域,向量和矩阵操作是解决问题的核心技能之一。Python 的 SymPy 库提供了强大的符号计算功能,能够高效地处理向量和矩阵的各种操作。本文将深入探讨如何使用 SymPy 进行向量和矩阵的创建、合并以及维度拓展等操作,并通过具体…...
2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...
现有的 Redis 分布式锁库(如 Redisson)提供了哪些便利?
现有的 Redis 分布式锁库(如 Redisson)相比于开发者自己基于 Redis 命令(如 SETNX, EXPIRE, DEL)手动实现分布式锁,提供了巨大的便利性和健壮性。主要体现在以下几个方面: 原子性保证 (Atomicity)ÿ…...
Spring Security 认证流程——补充
一、认证流程概述 Spring Security 的认证流程基于 过滤器链(Filter Chain),核心组件包括 UsernamePasswordAuthenticationFilter、AuthenticationManager、UserDetailsService 等。整个流程可分为以下步骤: 用户提交登录请求拦…...
Unity中的transform.up
2025年6月8日,周日下午 在Unity中,transform.up是Transform组件的一个属性,表示游戏对象在世界空间中的“上”方向(Y轴正方向),且会随对象旋转动态变化。以下是关键点解析: 基本定义 transfor…...
