我正在学习GraphQL,并且在GraphQL操作中使用棱镜绑定。当我启动我的Node.js服务器时,我面临这个nodemon错误,它给了我一个由graphql-cli自动生成的模式文件的路径。这个错误是关于什么的?

错误:

Internal watch failed: ENOSPC: System limit for number of file watchers reached, watch '/media/ rehans -sattar/Development/All projects/GrpahQl/graph-ql-course/graphql-prisma/src/generated


当前回答

在我的例子中,当我在Linux服务器上执行nodemon命令时,我打开了Visual Studio Code (SSH到服务器)。所以根据Juri Sinitson的回答,我只是关闭Visual Studio Code并再次运行nodemon命令。这很有效。

我的非恶魔命令:

Nodemon server.js通过NPM启动

其他回答

我认为这里给出的大多数答案都是正确的,但是使用systemctl命令重新启动我的服务解决了我的问题。检查下面的命令:

sudo systemctl restart systemd-sysctl.service

你应该遵循这样的答案:

cjs'

Or:

艾萨克·莫拉的

对于最新的Ubuntu版本,运行sudo sysctl——system重新读取这些设置。

然而,在我的情况下,我对这些配置文件的更改没有被选中,因为我已经在一段时间前调整了这些设置……然后就忘了。我把冲突的配置文件放在了错误的地方。

根据man sysctl。D,这些设置可以放在/etc/sysctl.d/*.conf、/run/sysctl.d/*.conf和/usr/lib/sysctl.d/*.conf中。

在我的例子中,我有两个文件:

/etc/sysctl.d/10-user-watches.conf
/usr/lib/sysctl.d/30-tracker.conf     <<< Older file, with lower limit

由于命名约定,我的旧文件是最后读取的,并具有优先级。

当我在Ubuntu机器上使用Visual Studio Code时,有时会遇到这个问题。

在我的情况下,下面的解决方法会有所帮助:

停止监视器,关闭Visual Studio Code,启动监视器,然后再次打开Visual Studio Code。

在Linux上,我实际上是用sudo运行的。 Sudo NPM启动

我也有同样的问题。然而,我的是来自Webpack的。值得庆幸的是,他们的网站上有一个很好的解决方案:

对于某些系统,查看许多文件可能会导致大量CPU或内存使用。可以使用正则表达式排除像node_modules这样的大文件夹:

文件webpack.config.js

module.exports = {
  watchOptions: {
    ignored: /node_modules/
  }
};