提高 WSL2 下的 nofile 限制

sgu*_*aty 1 config windows-subsystem-for-linux

我不是你所谓的高级 Linux 用户,所以我对一个可能愚蠢的问题表示歉意。

我正在尝试使用 WSL2 提高 UBUNTU 20.04 发行版的 NOFILE 限制,遵循本指南:cannot-increase-open-file-limit-past-4096-ubuntu

但是,当我尝试修改相应的.conf文件时,出现权限被拒绝的错误。当尝试从 Windows 和 VsCode 执行此操作时,我得到:

Failed to save 'system.conf': Command failed: "C:\Users\sague\AppData\Local\Programs\Microsoft VS Code\bin\code.cmd" --file-write "c:\Users\sague\AppData\Roaming\Code\code-elevated-mjlcag" "\\wsl$\Ubuntu-20.04\etc\systemd\system.conf" Error using --file-write: EPERM: operation not permitted, open '\\wsl$\Ubuntu-20.04\etc\systemd\system.conf'
Run Code Online (Sandbox Code Playgroud)

当尝试在 WSL2 终端(使用 Windows 终端)中使用 nano 执行此操作时,我得到:

 Error writing /etc/systemd/system.conf: Permission denied
Run Code Online (Sandbox Code Playgroud)

请帮忙,我被这个问题困扰了:')我很抱歉这可能是一个非常菜鸟的问题

Not*_*1ds 8

好吧,说实话,您犯一些新手错误,但不用担心 - 即使您克服了这些错误,您在 WSL 下尝试做的事情也并不容易。

  1. 首先,您尝试以普通用户身份编辑系统文件nano,导致Permission denied. 解决方法:sudo nano /etc/systemd/system.conf改用。但请参阅下面的 (3) 了解为什么这最终行不通。

  2. 其次,您尝试在 VSCode 下以普通用户身份编辑 WSL 系统文件。这是行不通的,因为 VSCode 按照设计始终以普通用户身份运行。也许可以让它在 下运行sudo,但这可能不值得付出努力。请注意,这也是在 VSCode 中运行“远程 - SSH”扩展(类似于您现在使用的“远程 - WSL”扩展)时的限制。

  3. 您正在尝试修改systemdWSL 下的配置,而 WSL 不支持该systemd配置,因此即使您成功编辑了文件,它也不会执行任何操作。

  4. 一旦你克服了这个问题,你的下一次尝试可能是(就像我们大多数人一样)尝试通过 提高 ulimit /etc/security/limits.conf,这正确的方法,但需要 WSL 下的技巧。该文件是一个 PAM 构造,并且......好吧,PAM 在登录时运行,并且我们不会在 WSL 中“登录”,因此 PAM 通常不会被调用。

正如我在 Ask Ubuntu 上的这个答案中所介绍的,hacky 解决方案(在这个 Github 线程中的许多答案的大力帮助下)是进行修改/etc/security/limits.conf,然后通过sudo“以您自己的用户身份重新登录”来强制 PAM 处理它通过:

sudo su $USER
Run Code Online (Sandbox Code Playgroud)

或者可能

sudo su - $USER # if you need to run as a login shell
Run Code Online (Sandbox Code Playgroud)

如果这些咒语不太适合您,Github 线程中还有一些其他建议。