AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / computer / 问题 / 1713269
Accepted
cryptic
cryptic
Asked: 2022-03-29 07:05:35 +0800 CST2022-03-29 07:05:35 +0800 CST 2022-03-29 07:05:35 +0800 CST

为什么将 Arch 的 bootstrap 镜像导入 WSL2 会导致挂载错误,但导入 Arch 的 Docker 镜像不会?

  • 772

我最近在 WSL2 上安装了 Arch,想知道为什么官方引导镜像导入失败,但导入提取的 Arch 的 Docker 镜像工作正常。

情况1

  • 从archlinux.org列出的镜像之一下载了最新的引导映像。
  • 重新打包它以摆脱root.x86_64子目录:
    fakeroot -- bash -c "tar -xf bootstrap.tar.gz && tar -czaf rootfs.tar.gz root.x86_64/*"
    
  • 移至.tarWindows 文件系统
  • 导入.tar并运行wsl -d Arch。这产生了以下错误,使发行版无用。
    Error mounting one of the file systems. Run 'dmesg' for more details.
    
  • 我尝试运行dmesg但wsl -d Arch --exec dmesg返回相同的先前错误,因此无法查明问题。

案例2

  • 使用最新的 Arch 镜像创建了一个 Docker 容器。
    docker run -t --name arch archlinux ls /
    
  • 将其导出为 tar 文件。
    docker export arch -o arch-wsl.tar
    
  • 进口的。冉wsl -d Arch。它立即让我陷入了bash.

知道为什么这两种情况会产生不同的结果吗?

linux arch-linux
  • 2 2 个回答
  • 440 Views

2 个回答

  • Voted
  1. NotTheDr01ds
    2022-03-29T07:50:36+08:002022-03-29T07:50:36+08:00

    简短的回答:

    您第一次尝试使用引导映像并fakeroot生成无效的 rootfs。它实际上并没有删除root.x86_64父目录。

    更多详情:

    以Error mounting one of the file systems. Run 'dmesg' for more details.我的经验,通常意味着存档不包含有效的(对 WSL 而言)rootfs。

    起初我认为这是由于导入了一个 gzip 压缩文件,因为默认的 for--export是一个简单的 tar(你在 Docker 步骤中这样做)。

    但是,我只是用 atar和 a进行了测试,无论.tar.gz哪种方式都对我有用。不过,我使用了稍微不同的步骤——具体来说,我使用sudo了而不是fakeroot因为我正在从现有的 Ubuntu 20.04 发行版中尝试它。 编辑:我也在fakeroot我的 Artix 发行版下试了一下,发现了问题。请参阅下面的“为什么您的 fakeroot 尝试不起作用”部分。

    我在以下方面取得了成功。首先,从 Ubuntu 20.04 开始:

    wget http://mirror.rackspace.com/archlinux/iso/2022.03.01/archlinux-bootstrap-2022.03.01-x86_64.tar.gz
    sudo tar --xattrs -xzvf archlinux-bootstrap-2022.03.01-x86_64.tar.gz
    cd root.x86_64/
    sudo tar --xattrs -cf ../archtest.tar .
    # or
    # sudo tar --xattrs -czf ../arch-wsl.tar.gz .
    mv ../arch-wsl.tar* /mnt/c/Users/<some_location_in_my_profile>
    # I have a standard WSL directory under my Documents folder
    

    然后从 PowerShell(显然,您已经熟悉这些步骤):

    cd <location_from_above>
    mkdir -p instances\arch
    wsl --import arch .\instances\arch .\arch-wsl.tar --version 2
    wsl ~ -d arch
    

    为什么您的 fakeroot 尝试不起作用

    我在 Artix 下运行了你的命令行来试用它,我可以看到问题所在。从它创建的焦油仍然有root.x86_64它。要摆脱它,您需要使用该-C/--directory选项来指定真正的根:

    fakeroot -- bash -c "tar -xf bootstrap.tar.gz && tar -C root.x86_64 -czaf rootfs.tar.gz ."
    

    但是,这仍然存在问题,因为结果存档在一些命令上没有适当的安全功能:

    tar: Ignoring unknown extended header keyword 'LIBARCHIVE.xattr.security.capability'
    tar: Ignoring unknown extended header keyword 'LIBARCHIVE.xattr.security.capability'
    

    尝试--xattrs像我在sudo上面做的那样使用,仍然无法正常工作,我现在不确定为什么:

    fakeroot -- bash -c "tar --xattrs -xf bootstrap.tar.gz  && tar --xattrs -C root.x86_64 -czaf rootfs.tar.gz ."
    

    结果是:

    tar: Ignoring unknown extended header keyword 'LIBARCHIVE.xattr.security.capability'
    tar: Ignoring unknown extended header keyword 'LIBARCHIVE.xattr.security.capability'
    tar: ./usr/bin/newuidmap: Unknown file type; file ignored
    tar: ./usr/bin/newgidmap: Unknown file type; file ignored
    tar: Exiting with failure status due to previous errors
    

    如果您能弄清楚为什么会失败fakeroot,请告诉我。但是这个sudo版本对我来说很好用。

    一些旁注:

    • 创建默认用户后,您需要使用这些步骤将其设置为 WSL 默认用户。

    • Arch 仍然是一个 Systemd 发行版,并且(您可能已经知道),Systemd 在 WSL 下没有得到很好的支持,因为 (a) WSL 的/init系统设置了 WSL/Windows 集成,以及 (b) Systemd 要求它是 PID1。

      我很快从 Arch 迁移到了 Artix,因为后者是基于 Arch 的无 Systemd 发行版。我仍然“早期”(已经使用了大约一个月),但结果令人鼓舞。Artix 支持 5 种不同的替代流程管理器,并且具有用于通过pacman(但不是 AUR)安装的大多数所有服务的脚本/单元文件。如果你想走这条路,请告诉我,我可以分享我的设置说明。

    • 1
  2. Best Answer
    cryptic
    2022-03-29T09:36:08+08:002022-03-29T09:36:08+08:00

    感谢@NotTheDr01ds 抽出时间并指出我之前的尝试和结果的问题tar。

    我发现使用bsdtarinclude withlibarchive可以完美地工作,而不是GNU tarwith fakeroot:

    fakeroot -- bash -c "bsdtar -xf bootstrap.tar.gz  && bsdtar -C root.x86_64 -czaf rootfs.tar.gz ."
    

    这导致完美的导入。然后,您可以继续初始化pacman密钥环和其他东西。

    至于为什么GNU tar会产生警告,我不确定。据此,这只是两个工具之间的兼容性冲突。我在这里找到了一个比较线程。

    • 0

相关问题

  • 如何让我的 Linux 机器看起来像是在运行 Windows?

  • 对于 cp 或 mv,是否有等同于 cd - 的东西?

  • 以 root 身份运行 docker 容器

  • 如何在域和 Linux 活动目录中启用指纹传感器

  • 如何在CentOS 7 中将Ctrl+C 永久更改为Ctrl+K?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何减少“vmmem”进程的消耗?

    • 11 个回答
  • Marko Smith

    从 Microsoft Stream 下载视频

    • 4 个回答
  • Marko Smith

    Google Chrome DevTools 无法解析 SourceMap:chrome-extension

    • 6 个回答
  • Marko Smith

    Windows 照片查看器因为内存不足而无法运行?

    • 5 个回答
  • Marko Smith

    支持结束后如何激活 WindowsXP?

    • 6 个回答
  • Marko Smith

    远程桌面间歇性冻结

    • 7 个回答
  • Marko Smith

    子网掩码 /32 是什么意思?

    • 6 个回答
  • Marko Smith

    鼠标指针在 Windows 中按下的箭头键上移动?

    • 1 个回答
  • Marko Smith

    VirtualBox 无法以 VERR_NEM_VM_CREATE_FAILED 启动

    • 8 个回答
  • Marko Smith

    应用程序不会出现在 MacBook 的摄像头和麦克风隐私设置中

    • 5 个回答
  • Martin Hope
    Saaru Lindestøkke 为什么使用 Python 的 tar 库时 tar.xz 文件比 macOS tar 小 15 倍? 2021-03-14 09:37:48 +0800 CST
  • Martin Hope
    CiaranWelsh 如何减少“vmmem”进程的消耗? 2020-06-10 02:06:58 +0800 CST
  • Martin Hope
    Jim Windows 10 搜索未加载,显示空白窗口 2020-02-06 03:28:26 +0800 CST
  • Martin Hope
    v15 为什么通过电缆(同轴电缆)的千兆位/秒 Internet 连接不能像光纤一样提供对称速度? 2020-01-25 08:53:31 +0800 CST
  • Martin Hope
    andre_ss6 远程桌面间歇性冻结 2019-09-11 12:56:40 +0800 CST
  • Martin Hope
    Riley Carney 为什么在 URL 后面加一个点会删除登录信息? 2019-08-06 10:59:24 +0800 CST
  • Martin Hope
    zdimension 鼠标指针在 Windows 中按下的箭头键上移动? 2019-08-04 06:39:57 +0800 CST
  • Martin Hope
    jonsca 我所有的 Firefox 附加组件突然被禁用了,我该如何重新启用它们? 2019-05-04 17:58:52 +0800 CST
  • Martin Hope
    MCK 是否可以使用文本创建二维码? 2019-04-02 06:32:14 +0800 CST
  • Martin Hope
    SoniEx2 更改 git init 默认分支名称 2019-04-01 06:16:56 +0800 CST

热门标签

windows-10 linux windows microsoft-excel networking ubuntu worksheet-function bash command-line hard-drive

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve