有人尝试过将 Ubuntu(在本例中使用 21.10)从虚拟机(如果涉及的话,由 VirtualBox 提供支持)迁移到 WSL 吗?在单个主机内进行迁移。
对源 (vm) 进行映像处理然后还原到目标 (WSL) 的效果如何?硬件层很有可能有所不同。
答案1
一般来说,如果您可以获得虚拟机的 tarball 根文件系统,那么(理论上)应该非常简单,尽管我还没有尝试过。主要的技巧是获得rootfs.tar
“恰到好处”的效果。注意事项:
它将需要包含来自虚拟机的所有“正常”文件系统,但您当然可以忽略诸如
/proc
、、等内容/sys
。/dev
您应该将
--xattrs
标志添加到 tar 中,以确保获取所有扩展属性。这不是默认设置。
一旦你有了有效的 rootfs tarball,导入 WSL 就很容易了:
wsl --import Ubuntu2110 <directory> <tarball> --version 2
第一个参数(发行版名称)可以是任何你喜欢的,但我建议避免使用,Ubuntu
因为这是默认 WSL 发行版的名称并且可能会导致冲突。
我倾向于设置我的 WSL“目录”:
- 可以通过 PowerShell 轻松访问的位置,例如
~\Documents\WSL
- 适用
~\Documents\WSL\instances\Ubuntu2110
于我的发行版(以及其他发行版) - 有
~\Documents\WSL\images\Ubuntu2110.tar
(和其他人) 我的 rootfs 图像。
硬件层很有可能有所不同。
这并不是你想象中的问题。WSL2 实例实际上更多的是“容器”,而不是虚拟机。是VM 正在运行,但您无法访问它。VM 本身负责处理发行版/实例/容器的导入和运行。所有 WSL2 实例都共享相同的内核空间、虚拟硬件、网络等,但每个实例都有自己的 PID 命名空间、chroot 等(总结一下)。
WSL 与 VM 之间的差异
系统启动
当然,你会发现最大的不同是 VM 通过 Systemd 进行所有配置。这在 WSL2 上不会发生,因为 Systemd 不受支持。相反,WSL 使用自己的系统
/init
来引导与系统 VM 和 Windows 的互操作性。这意味着,当你从导入的 VM 启动 WSL2 实例时,没有什么即将运行。
您需要手动启动每项服务。或者使用其他自动启动技术。
其他 Systemd 问题
虽然您可以在没有 Systemd 的情况下在 Ubuntu 中启动许多服务,但越来越多的服务依赖于 Systemd。这些在 WSL 下可能会出现问题。虽然有在 WSL 中运行 Systemd 的变通方法,但目前它们往往是“黑客式的”。
GUI 应用程序
另外,请记住,WSL 是主要命令行环境。要运行 GUI 应用程序,您需要运行以下任一程序:
- Windows 11
- Windows 中的第三方 X 服务器
- 或者
xrdp
桌面环境
最后,由于上述原因以及其他一些原因,桌面环境可能会变得更具挑战性:
- 有些需要 Systemd
- 在 Windows 中运行全屏 Linux GUI 应用程序可能会带来键绑定挑战(例如,Alt+Tab将被 Windows 拦截并从您的 DE 中转移出去)。
- Windows 11 中的 WSLg 使用 Weston,它提供了自己的窗口管理器