我有一个问题与Node.js和上传文件到服务器。为了上传文件到服务器,我使用这个插件。当开始向服务器上传文件时,Node.js进程崩溃并显示错误:

错误:ENOSPC。

服务器代码无法运行。

$ df -h
Filesystem      Size  Used Avail Use% Mounted on
/dev/xvda1      7.9G  4.1G  3.5G  55% /
udev            288M  8.0K  288M   1% /dev
tmpfs           119M  168K  118M   1% /run
none            5.0M     0  5.0M   0% /run/lock
none            296M     0  296M   0% /run/shm
/dev/xvdf       9.9G  3.0G  6.5G  32% /vol
overflow        1.0M  1.0M     0 100% /tmp

当前回答

解决我问题的一个简单方法是:

npm cache clear

NPM或者由它控制的进程正在监视太多的文件。更新构建节点上的max_user_watches可以永远修复它。对于debian,在终端上放以下命令:

echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p

如果你想知道如何增加inotify观察者的数量,只需要点击链接。

其他回答

如果linux文件系统上的/tmp挂载是作为溢出挂载的(通常大小为1MB),这可能是由于您没有指定/tmp作为自己的分区,您的根文件系统被填满,/tmp被重新挂载作为备用。

要解决这个问题,在你清理空间后,只需卸载备份,它应该重新安装在它原来的位置:

sudo umount overflow

执行以下命令避免ENOSPC:

echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p

对于Arch Linux,将这一行添加到/etc/sysctl.d/99-sysctl.conf:

fs.inotify.max_user_watches=524288

然后执行:

sysctl --system

这在重启过程中也会持续。 技术细节来源

这表明VS Code文件监控器正在耗尽句柄,因为工作区很大,包含很多文件。已达到手表的最大限制,您可以通过运行:

cat /proc/sys/fs/inotify/max_user_watches

运行以下代码解决此问题:

fs.inotify.max_user_watches=524288

在我的情况下,在linux上,sudo解决了这个问题。

例子:

sudo gulp dev

就我而言,我是这样做的

yarn cache clean

npm cache verify

rm -rf node_modules/

yarn install