WSL2 - Linux 相对符号链接在仅针对 \\wsl$\ 挂载点从 Windows 访问时损坏

Xav*_*ero 12 linux windows symlink windows-subsystem-for-linux wsl-2

问题

我真的很挣扎相对符号链接WSL2它们在Linux的本地文件系统创建的,我想,当通过共享点访问文件\\wsl$\distro-name\whatever-他们只是打破。

环境

我已经wsl2在我的 Windows10 中激活了。我有一个Ubuntu-20.04

WSL2 中的 Ubuntu

对我的编码工作流程的影响

损坏的符号链接禁止我在“从 Windows 中的 IDE 编辑”时无缝地“在 wsl2 中执行”。

实际用例(但不限于):开发两个集成项目:一个带有应用程序的 repo 和另一个与库一起存在的 repo。该应用程序符号链接库:

  • 主程序在 /files/repos/my-nice-app
  • 图书馆也在 /files/repos/my-nice-lib
  • my-nice-app/libs/my-nice-lib 是一个符号链接 ../../my-nice-lib
  • windows中的智能IDE,在应用程序打开时进行操作 \\wsl$\Ubuntu-20.04\files\repos\my-nice-app

通过此设置,该位置\\wsl$\Ubuntu-20.04\files\repos\my-nice-app\libs\my-nice-lib应映射到\\wsl$\Ubuntu-20.04\files\repos\my-nice-lib

但它不起作用。IDE 中的所有代码完成都搞砸了,因为符号链接没有很好地解映射并且 IDE 无法读取库的类和定义。

如何重现工作示例

工作示例。第 1 步 - 准备

每当我在 NTFS 文件系统中从 linux 创建符号链接时,它都会在 windows 中正确解码

反面相同:如果我从 windows(使用 CMD 和mklink或 Powershell 使用New-Item创建链接,它们会在 linux正确解码

想象一下这个场景:

  1. 我有这个 dir:/mnt/c/tmp对应于C:\tmp.

  2. 我把一些内容放到一个文件中original.txt。我为此使用了 linux bash。 在 NTFS 上创建内容

  3. 在 linux 中,我做了一个linux.txt指向original.txt. 在 NTFS 上从 Linux 创建链接

  4. 然后我从窗户做。从带有mklink命令的 CMD : 在 NTFS 上从 CMD 创建链接

  5. 我什New-Item至可以使用提升的 powershell 中的命令 在 Windows 端执行符号链接在 NTFS 上从 PowerShell 创建链接

到这里我应该有一个文件original.txt和三个链接linux.txtcmd.txt并且powershell.txt

工作示例。第 2 步 - 列出符号链接

成功:我确实在 3 个 shell 中看到了所有这些:linux、cmd 和 powershell:

在 NTFS 中列出

在 Linux(图像中的 1)中,我们看到它们是符号链接,以及来自 CMD(图像中的 2)和 powershell(图像中的 3)中的符号链接。

Linux 和 CMD 也报告了“解映射”(图像中的 4)。由于cmd.txtlinux.txt都是相对符号链接,因此后面没有什么可做的,只要明白它们是链接就完成了。

由于某种我不关心这个问题的原因,Powershell 将相对符号链接提升为绝对符号链接。这显示了一个非常有趣的效果:

幕后的某个人一定在做某种翻译工作,在这种情况下做得很好(图像中的 5):虽然从 linuxpowershell.txt它指向一条以/mnt/c/...windows 解释器开头的路径,但它认为它指向C:\....

工作示例。第 3 步 - 通过符号链接访问内容

现在是时候看看我是否可以cattype在 Windows 中)所有这些的内容......

在 NTFS 中访问

这里不需要解释。包括相对链接和绝对链接在内的所有 9 种组合(3 种创建方法 x 3 种消耗方法)都可以完美运行。

现在是打破规则的时候了......

如何重现失败的例子

我将执行完全相同的过程,但不是在 Windows 上执行,而是在 Windows/mnt/c/tmp/tmp和 Windows 中执行,而不是C:\tmp\\wsl$\Ubuntu-20.04\tmp.

开始吧...

失败的例子。第 1 步 - 准备

我从linux开始。/tmpWSL2文件系统上导航并创建一些虚拟内容。我继续做符号链接。

创建内容 wsl2

当我尝试使用 CMD 去那里时,我真的不能,因为它抱怨是 UNC 路径:

在 CMD 上导航 UNC

我会改变我的策略,我会做一个网络挂载以获得一个驱动器号,看看CMD是否更喜欢它。我将W:用于WSL2文件系统。在图像中:1 = 我创建它,2 = 我检查它已创建,3 = 我导航到tmpWSL2。

创造W:

但是现在……哦,惊喜!!!当我尝试从 CMD 执行符号链接时...它拒绝访问:

从 WSL2 上的 CMD 链接

让我们尝试使用提升的 PowerShell ...

在此图像中,我可以看到我可以正确导航到 UNC 路径(图像中的 1),但是在尝试创建链接时...繁荣...图像中的 2:“符号链接与指定路径不兼容” :

从 WSL2 上的 PowerShell 链接

所以只有一种方法可以在 WSL2 中创建符号链接:从 linux 内部。让我们看看如何列出并访问它。

失败的例子。第 2 步 - 列出 + 访问

开始,linux 可以看到 linux 链接(当然):

Linux 访问 WSL2

但是当移动到 CMD 时,列表显示“JUNCTION”而不是“SYMLINK”,因为它在 NTFS 上显示它,另外在尝试访问它时,它会中断:

CMD 访问 WSL2

最后,当进入 Powershell 时,行为类似:它看到“它就在那里”,但无法访问内容:

PowerShell 访问 WSL2

最后的考虑

  • 我什至不要求绝对路径转换(如在 NTFS 作品中所示)。我只是对相对链接感到满意
  • 我已经用文件做到了这一点。但它也失败了目录。

Sooooooooo 问题

我怎样才能WSL2在 linux 端和 windows 端都有一个正常工作的符号链接?

如果它是一个错误,它是什么模块?内核?WSL 本身?P9协议?我很乐意做出贡献,但我什至不知道我应该为哪个项目做出贡献。

目前已完成调查

我已经深入阅读了所有这些内容:

还有更多,但仍然没有运气。