Gramex 在 Docker 容器中引发“inotify watch limited reach”错误

问题描述

随着时间的推移,我们在生产环境中部署 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的限制而失败。

相关问答

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