在多通道 Ubuntu 20.10 下编译 C++ 时出现间歇性“找不到文件”错误

问题描述

我正在尝试使用 multipass 来生成构建环境,源代码位于主机上。这个想法是我将源代码从主机挂载到 VM 中,然后从 VM 内部运行构建。 (multipass mount src ubuntu:/home/ubuntu/src)。

我要构建的是一个相对较大的 c++ 项目,其中包含大量包含文件。构建系统为 CMake + ninja 和 clang 8.0。

问题是构建失败,并出现各种标头的“找不到文件错误。每次“丢失”的文件都不同。我说“丢失”是因为文件实际上都在那里。

这似乎与 Intermittent,random 'file not found' errors under Windows Subsystem for Linux (WSL) 完全相同,但使用建议的解决方法并没有帮助(例如,我尝试在 ninja 中设置 -j1)。

是否知道是什么原因导致了这种情况以及是否有解决方法

我的主机是 macOS Catalina,多通道 VM 实例是 Ubuntu 20.10。 multipass 本身是 1.5.0。

解决方法

我最终 opening a PR 加入了 multipass 团队。经过一番调试,我们发现了两个问题:

  1. macOS Catalina 的默认 maxfiles 限制为 256,在编译大型项目时可能会达到该限制。
  2. libssh 中有一个限制,它被 multipass 用来进行挂载。

要解决此问题,您需要:

  1. 通过例如增加 macOS 中的 maxfiles 限制following this
  2. 通过 (1) 在 macOS 中安装 osxfuse,(2) 在设置 -> 共享中启用远程登录和 (3) 在 VM 中手动挂载文件夹
mkdir <mount_dir>
sshfs <host_user>@<host_ip>:<host_directory> <mount_dir>

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...