
devodev/inotify:
inotify API 提供了一种监控文件系统事件的机制。Inotify 可用于监控单个文件或目录。当监控目录时,inotify 将返回目录本身及其内部文件的事件。
inotify-tools 软件包包含两个命令行工具(inotifywait、inotifywatch),允许与 Inotify API 交互。
docker-inotify 提供基于 Alpine 的镜像,包含 inotify-tools 软件包、bash 以及一系列网络相关命令行工具(如 curl、netcat 等)。它还包含轻量级脚本 inotifywait.sh,可监控文件和/或目录并将事件发送到用户定义的脚本。该脚本可通过环境变量完全配置。
此镜像的主要用例是提供一种基于配置文件更改触发操作的简单方法。只需在边车容器中挂载要监控的卷,并提供事件接收时触发的脚本即可。
inotifywait 进程监控 INOTIFY_TARGET,并使用触发的事件数据作为参数运行 INOTIFY_SCRIPT。
使用默认配置值时,脚本将接收以下参数:
| argv | 名称 |
|---|---|
$1 | 时间戳 |
$2 | 被监控文件/目录路径 |
$3 | 事件名称 |
$4 | 文件名(若监控目录) |
监控事件:
modify delete delete_self
被监控文件被修改/删除时:
bash22:48:36 /test MODIFY 22:48:36 /test DELETE_SELF
被监控目录中的文件被修改/删除时:
bash22:48:36 /test/ MODIFY a_file 22:48:36 /test/ DELETE a_file
以下部分描述如何配置监控进程。
| 变量名 | 是否必填 | 默认值 | 描述 |
|---|---|---|---|
| INOTIFY_TARGET | 是 | 空 | 要监控事件的文件或目录路径 |
| INOTIFY_SCRIPT | 是 | 空 | 事件发生时要运行的脚本 |
| INOTIFY_QUIET | 否 | true | 若设置,抑制日志消息 |
默认值在大多数情况下适用。
有关
inotifywait可用标志的更多详情,请参见 inotify-tools。布尔值可设置为任何值以被视为 true。
| 变量名 | 默认值 | 描述 |
|---|---|---|
| INOTIFY_CFG_CSV | false | (布尔值)使用 CSV 格式输出事件 |
| INOTIFY_CFG_EVENTS | modify delete delete_self | 空格分隔的要监控事件列表 |
| INOTIFY_CFG_EXCLUDE | - | 使用 POSIX 正则模式排除文件子集 |
| INOTIFY_CFG_EXCLUDEI | - | 与 INOTIFY_CFG_EXCLUDE 相同,但不区分大小写 |
| INOTIFY_CFG_INCLUDE | - | 使用 POSIX 正则模式包含文件子集 |
| INOTIFY_CFG_INCLUDEI | - | 与 INOTIFY_CFG_INCLUDE 相同,但不区分大小写 |
| INOTIFY_CFG_QUIET | true | (布尔值)抑制 inotifywait 日志 |
| INOTIFY_CFG_RECURSIVE | false | (布尔值)监控所有子目录,深度不限 |
| INOTIFY_CFG_TIMEFMT | %H:%M:%S | 用于显示事件中 %T 的 strftime 兼容模式 |
| INOTIFY_CFG_TIMEOUT | - | 无事件接收 X 秒后超时并重新设置监控器 |
以下示例定义包含应用容器和 inotify 边车容器的 Pod,当挂载的配置文件(此处为共享 ConfigMap)更新时,边车容器将触发服务器重载。
yaml--- apiVersion: v1 kind: ConfigMap metadata: name: application-conf data: application.conf: |- [server] property=value --- apiVersion: v1 kind: ConfigMap metadata: name: inotify-example-reload-script data: reload-server.sh: |- #!/usr/bin/env bash timestamp="$1"; shift file="$1"; shift event="$1"; shift echo "[${timestamp}] 文件: ${file} 已更改(${event}),触发服务器重载" curl -s -X POST http://localhost:8080/reload --- apiVersion: v1 kind: Pod metadata: name: inotify-example spec: containers: - name: application image: application/server:latest ports: - containerPort: 8080 name: server volumeMounts: - name: conf mountPath: /conf/application.conf readOnly: true subPath: application.conf - name: reload-server-sidecar image: devodev/inotify:latest env: - name: INOTIFY_TARGET value: "/conf/application.conf" - name: INOTIFY_SCRIPT value: "/reload-server.sh" volumeMounts: - name: conf mountPath: /conf/application.conf readOnly: true subPath: application.conf - name: reload-script mountPath: /reload-server.sh readOnly: true subPath: reload-server.sh volumes: - name: conf configMap: name: application-conf - name: reload-script configMap: name: inotify-example-reload-script # 确保脚本可执行 defaultMode: 0777
manifest unknown 错误
TLS 证书验证失败
DNS 解析超时
410 错误:版本过低
402 错误:流量耗尽
身份认证失败错误
429 限流错误
凭证保存错误
来自真实用户的反馈,见证轩辕镜像的优质服务