window 下使用docker

基于 osrf/ros:humble-desktop-full-jammy 这个镜像启动一个 Docker 容器,我会给你提供不同场景下的启动命令,涵盖基础启动、端口映射、目录挂载等常用需求,方便你直接使用。

一、基础启动命令(最常用)

这是启动 ROS 2 Humble 容器的基础命令,会进入容器的交互式终端,适合快速验证和调试:

bash

运行

复制代码
# 基础启动:--rm 退出容器后自动删除容器,-it 交互式终端,--name 给容器命名(方便管理)
docker run --rm -it --name ros_humble_container osrf/ros:humble-desktop-full-jammy

执行后会直接进入容器内部的 bash 终端,你可以在里面执行 ROS 2 命令(比如ros2 --version)验证环境。

二、实用增强版启动命令(推荐)

如果需要在容器中运行 GUI 程序(比如 RViz、Gazebo)、挂载本地目录、映射端口,使用以下命令(Windows PowerShell/CMD 通用):

bash

运行

复制代码
# 增强版启动:支持GUI、挂载本地目录、网络主机模式
docker run --rm -it ^
    --name ros_humble_container ^
    --env="DISPLAY" ^
    --env="QT_X11_NO_MITSHM=1" ^
    --volume="/tmp/.X11-unix:/tmp/.X11-unix:rw" ^
    --volume="%cd%/ros_ws:/root/ros_ws:rw" ^  # 挂载本地ros_ws目录到容器/root/ros_ws(Windows)
    --net=host ^  # 主机网络模式,方便ROS 2节点通信
    osrf/ros:humble-desktop-full-jammy
关键参数说明:

表格

参数 作用
--env="DISPLAY"/QT_X11_NO_MITSHM=1 支持容器内 GUI 程序(RViz/Gazebo)显示
--volume="/tmp/.X11-unix:/tmp/.X11-unix:rw" 共享 X11 套接字,实现 GUI 窗口映射到主机
--volume="%cd%/ros_ws:/root/ros_ws:rw" 挂载本地ros_ws目录到容器,本地修改的代码会同步到容器(Windows 用 % cd%,Linux/macOS 用 $(pwd))
--net=host 容器使用主机网络,ROS 2 节点可直接和主机通信,无需额外端口映射

三、Windows 下 GUI 显示额外配置(重要)

如果需要在 Windows 上显示容器内的 ROS 2 GUI 程序(如 RViz),还需要:

  1. 安装 X Server 软件(比如 VcXsrv):

    • 下载地址:https://sourceforge.net/projects/vcxsrv/
    • 安装后启动 XLaunch,保持默认配置(Multiple windows → Next → Start no client → Next → 勾选 "Disable access control" → Finish)。
  2. 在启动容器前,在 PowerShell 中执行以下命令(设置 DISPLAY 环境变量): bash

    运行

    复制代码
    # 获取本机IP并设置DISPLAY
    $env:DISPLAY = (Get-NetIPAddress -AddressFamily IPv4 | Where-Object { $_.InterfaceAlias -match 'Ethernet|Wi-Fi' }).IPAddress + ":0.0"
  3. 再执行上面的增强版启动命令,即可正常显示 GUI 窗口。

四、容器常用操作

bash

运行

复制代码
# 查看运行中的容器
docker ps

# 停止容器(如果没加--rm,需要手动停止)
docker stop ros_humble_container

# 重新启动已停止的容器
docker start ros_humble_container

# 进入已运行的容器(新开终端)
docker exec -it ros_humble_container /bin/bash

总结

  1. 基础启动docker run --rm -it --name ros_humble_container osrf/ros:humble-desktop-full-jammy,适合快速验证环境。
  2. 增强启动:添加 GUI 支持、目录挂载、主机网络,适合实际开发和运行 ROS 2 程序。
  3. Windows GUI:需安装 VcXsrv 并设置 DISPLAY 环境变量,才能显示 RViz/Gazebo 等窗口。
相关推荐
DaisyMosuki1 小时前
个人实现大数加减乘(高精度加减乘)
算法·高精度·大数
子午1 小时前
【岩石种类识别系统】Python+深度学习+人工智能+算法模型+图像识别+TensorFlow+2026计算机毕设项目
人工智能·python·深度学习
郭逍遥1 小时前
[Godot] 通过AABB包围盒和射线法检测碰撞
算法·游戏引擎·godot
格林威1 小时前
Baumer相机镜面反射区域遮蔽重建:恢复缺失纹理的 6 个关键技术,附 OpenCV+Halcon 实战代码!
人工智能·opencv·计算机视觉·视觉检测·工业相机·智能相机·堡盟相机
大黄说说1 小时前
解锁 .NET 性能极限:深入解析 Span 与零拷贝内存艺术
java·数据结构·算法
iFeng的小屋1 小时前
【2026最新xhs爬虫】用Python批量爬取关键词笔记,异步下载高清图片!
笔记·爬虫·python
知识即是力量ol1 小时前
深入理解 Snowflake 雪花算法:原理、本质、趋势递增问题与分布式顺序困境全解析
java·分布式·算法·雪花算法·snowflake·全局唯一id·分布式id生成器
okclouderx1 小时前
【Easy-Vibe】【task4】给原型加上 AI 能力
人工智能·trae·ai ide·vibe coding·easy vibe
爱看科技1 小时前
Pico携“Project Swan”头显亮相GDC!Meta/阿里/微美全息加速进军眼镜市场前沿!
人工智能