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。"

相关推荐
新新学长搞科研2 小时前
【智慧城市专题IEEE会议】第六届物联网与智慧城市国际学术会议(IoTSC 2026)
人工智能·分布式·科技·物联网·云计算·智慧城市·学术会议
❀͜͡傀儡师2 小时前
基于大语言模型的简历分析和模拟面试系统
人工智能·语言模型·面试
rainbow68892 小时前
PCL点云处理算法全解析
算法
是小蟹呀^2 小时前
Focal Loss:解决长尾图像分类中“多数类太强势”的损失函数
人工智能·机器学习·分类
jmxwzy2 小时前
Linux常用命令
linux
马拉AI2 小时前
VAE不再必要?北大PixelGen:像素扩散反超Latent Diffusion,重塑生成新范式
人工智能·计算机视觉
不做无法实现的梦~2 小时前
思翼mk32遥控器配置图传和数传教程
linux·嵌入式硬件·机器人·自动驾驶
代码无bug抓狂人2 小时前
C语言之可分解的正整数(蓝桥杯省B)
c语言·开发语言·算法
量子-Alex2 小时前
【大模型技术报告】Seed-Thinking-v1.5深度解读
人工智能·算法