问题描述
随着时间的推移,我们在生产环境中部署 Gramex 门户时看到以下错误。
Inotify._raise_error()
File "/opt/conda/lib/python3.7/site-packages/watchdog/observers/inotify_c.py",line 421,in _raise_error
raise OSError(errno.ENOSPC,"inotify watch limit reached")
OSError: [Errno 28] inotify watch limit reached
我们部署后不会立即发生错误。它在部署后 1 或 2 小时后发生。之后,门户停止工作。当应用在 2 或 3 小时后停止响应时,我们将重新启动 docker 容器。
解决方法
在您的 watch: false
中的 app:
下设置 gramex.yaml
。
app:
watch: false
你可以增加主机中的inotify limit,但是you can't set these in docker containers。
这意味着如果您的文件发生更改,则需要重新启动 Gramex。但是不会因为inotify的限制而失败。