专业解析 .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? 为了评估第𝑗层的激活值,我们需要𝑐个输入来获…...
后进先出(LIFO)详解
LIFO 是 Last In, First Out 的缩写,中文译为后进先出。这是一种数据结构的工作原则,类似于一摞盘子或一叠书本: 最后放进去的元素最先出来 -想象往筒状容器里放盘子: (1)你放进的最后一个盘子(…...
浅谈 React Hooks
React Hooks 是 React 16.8 引入的一组 API,用于在函数组件中使用 state 和其他 React 特性(例如生命周期方法、context 等)。Hooks 通过简洁的函数接口,解决了状态与 UI 的高度解耦,通过函数式编程范式实现更灵活 Rea…...
React hook之useRef
React useRef 详解 useRef 是 React 提供的一个 Hook,用于在函数组件中创建可变的引用对象。它在 React 开发中有多种重要用途,下面我将全面详细地介绍它的特性和用法。 基本概念 1. 创建 ref const refContainer useRef(initialValue);initialValu…...
《Playwright:微软的自动化测试工具详解》
Playwright 简介:声明内容来自网络,将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具,支持 Chrome、Firefox、Safari 等主流浏览器,提供多语言 API(Python、JavaScript、Java、.NET)。它的特点包括&a…...
前端导出带有合并单元格的列表
// 导出async function exportExcel(fileName "共识调整.xlsx") {// 所有数据const exportData await getAllMainData();// 表头内容let fitstTitleList [];const secondTitleList [];allColumns.value.forEach(column > {if (!column.children) {fitstTitleL…...
Robots.txt 文件
什么是robots.txt? robots.txt 是一个位于网站根目录下的文本文件(如:https://example.com/robots.txt),它用于指导网络爬虫(如搜索引擎的蜘蛛程序)如何抓取该网站的内容。这个文件遵循 Robots…...
【Java_EE】Spring MVC
目录 Spring Web MVC 编辑注解 RestController RequestMapping RequestParam RequestParam RequestBody PathVariable RequestPart 参数传递 注意事项 编辑参数重命名 RequestParam 编辑编辑传递集合 RequestParam 传递JSON数据 编辑RequestBody …...
MySQL 8.0 OCP 英文题库解析(十三)
Oracle 为庆祝 MySQL 30 周年,截止到 2025.07.31 之前。所有人均可以免费考取原价245美元的MySQL OCP 认证。 从今天开始,将英文题库免费公布出来,并进行解析,帮助大家在一个月之内轻松通过OCP认证。 本期公布试题111~120 试题1…...
安卓基础(aar)
重新设置java21的环境,临时设置 $env:JAVA_HOME "D:\Android Studio\jbr" 查看当前环境变量 JAVA_HOME 的值 echo $env:JAVA_HOME 构建ARR文件 ./gradlew :private-lib:assembleRelease 目录是这样的: MyApp/ ├── app/ …...
音视频——I2S 协议详解
I2S 协议详解 I2S (Inter-IC Sound) 协议是一种串行总线协议,专门用于在数字音频设备之间传输数字音频数据。它由飞利浦(Philips)公司开发,以其简单、高效和广泛的兼容性而闻名。 1. 信号线 I2S 协议通常使用三根或四根信号线&a…...
