window wsl环境: autoware有日志,没有rviz界面/ autoware起不来

报错:

  1. 运行autoware报错: ERROR rviz2-40: process has died [pid 27797, exit code -6, cmd '/opt/ros/humble/lib/rviz2/rviz2 -d /root/work_space/autoware/install/autoware_launch/share/autoware_launch/rviz/autoware.rviz -s

2.运行rviz2报错:

root@1abfb637b0c5:~/work_space/autoware# rviz2

qt.qpa.xcb: could not connect to display :0

qt.qpa.plugin: Could not load the Qt platform plugin "xcb" in "" even though it was found.

This application failed to start because no Qt platform plugin could be initialized. Reinstalling the application may fix this problem.

Available platform plugins are: eglfs, linuxfb, minimal, minimalegl, offscreen, vnc, xcb.

Aborted (core dumped)

1. 你遇到了什么问题?(Symptoms)

核心问题是:Docker 容器内的图形化程序(Rviz2、xeyes)无法把画面投射到你的 Windows 屏幕上。

在这个过程中,你经历了三个阶段的报错:

  1. 找不到显示器qt.qpa.xcb: could not connect to display :0(Rviz2 瞎了,找不到屏幕)。

  2. 挂载错误HTTP code 400 ... not a directory(Docker 启动时,把主机的一个文件夹错误地当成文件挂载了)。

  3. 工具缺失xeyes: command not found(容器里没装测试工具)。


2. 为什么会这样?(Root Cause)

根本原因在于 "一山不容二虎" 导致的 X Server(显示管家)冲突

  • 冲突点:你的电脑里有两套图形显示方案。

    • 方案 A (WSLg):微软官方自带的。

    • 方案 B (MobaXterm):你自己安装的终端软件自带的。

  • 打架过程

    • 我最开始让你开启 WSLg (guiApplications=true),但这需要你的 Windows 系统组件支持。

    • 你的 MobaXterm 也在后台运行,它抢占了显示端口。

    • Docker 夹在中间,不知道该把画面发给谁(发给 :0 没人理,发给 localhost 也不通)。

  • 最终解决 :我们放弃了官方 WSLg,强制回退到 MobaXterm 方案 ,并明确告诉 Docker:"你的屏幕在 Windows 主机上(host.docker.internal)"。


3. 你做了哪些改动?(Change Log)

为了解决问题,我们对系统配置做了以下关键修改:

  1. 修改 Windows WSL 配置 (.wslconfig):

    • 改动 :将 guiApplications=true 改回了 false

    • 目的:关闭微软官方的图形功能,避免干扰 MobaXterm。

  2. 调整 MobaXterm 设置

    • 改动 :Settings -> X11 -> X11 remote access 改为 Full

    • 目的:允许"陌生人"(Docker 容器)连接 MobaXterm 的屏幕,防止被防火墙拦截。

  3. 容器内安装软件

    • 操作apt install x11-apps

    • 目的 :安装 xeyes 用于测试。


4. 你执行了哪些关键命令?(Command History)

这是解决问题的"通关密码":

  • 检查显示变量 (在 WSL 中): echo $DISPLAY -> 确认了是 localhost:10.0 (代表 MobaXterm 接管了)。

  • 进入容器docker exec -it 1abfb637b0c5 /bin/bash

  • 【最关键】在容器内指路export DISPLAY=host.docker.internal:0.0 (这句话的意思是:嘿 Docker,屏幕不在你这儿,在你的房东(host)那里)

  • 测试验证xeyes -> 成功弹窗。


5. 以后要如何解决?(SOP - 标准操作流程)

以后只要你重新开启电脑,或者重启了 Docker,只需按这个固定流程操作,保证 100% 能行

第一步:准备工作
  1. 打开 MobaXterm

  2. 确保右上角的 X Server 图标是绿色的(亮起的)。

第二步:启动docker,进入 Docker

启动docker: 重启docker,打开ubuntu,删除文件夹,建立文件夹,启动docker

进入docker:

使用 MobaXterm 连接你的 WSL,然后输入:

复制代码
# 查 ID
docker ps 
# 进容器
docker exec -it <你的容器ID> /bin/bash
第三步:连接屏幕(必做!)

每次进入容器后,第一件事就是输这行命令:

复制代码
export DISPLAY=host.docker.internal:0.0



#"喂,Docker 里的所有程序听好了(export),如果有画面要显示,请不要自己在内部消化,全部发送给(DISPLAY=)宿主机(host.docker.internal)上的第 0 号屏幕(:0.0)!"
第四步:启动rviz2测试
复制代码
rviz2

✅ 总结口诀: "开 Moba,进 Docker,输 export,跑 Rviz。"

相关推荐
冬奇Lab17 小时前
Skill 系列(05):Skill 工作流串联——4 种模式实测,并发加速 1.5x
人工智能·开源
冬奇Lab17 小时前
每日一个开源项目(第141篇):hiring-agent - HackerRank 开源了他们的简历评分系统,你的简历能得几分?
人工智能·面试·开源
甲维斯17 小时前
又升级咯!坦克大战2026,科技与复古并存!
前端·人工智能·游戏开发
姗姗来迟了19 小时前
用React Hook封装AI对话状态
人工智能
Goodbye19 小时前
从 Token 到 Embedding:LLM 核心基础深度解析
javascript·人工智能
阿瑞IT19 小时前
AI Agent 在甘特计划变更场景中的动态响应工程实践
人工智能
用户9385156350720 小时前
工具调用背后:LLM 如何突破“缸中大脑”,操控真实世界?
javascript·人工智能
Goodbye20 小时前
从函数到智能:LLM Tool Use 深度解析
javascript·人工智能