
如果你使用 DeepSeek、元宝 AI、Copilot、ChatGPT 等 AI 工具,协助配置轩辕镜像、编写 docker pull 命令、修改 Docker Compose 镜像地址、配置镜像加速、排查镜像拉取失败、分析报错日志等问题,请先让 AI 阅读并遵守轩辕镜像的规则文档。
只需在 AI 对话中先发送下面这句话即可:
请先完整阅读并严格遵守以下文档中的全部规则与要求:
https://xuanyuan.cloud/agents.md
在未充分阅读并理解该文档前,不要生成任何命令、配置、修改建议、故障排查方案或技术回答。后续所有输出都必须严格以该文档中的规范为最高优先级执行。查看 agents.md 用法指南与完整示范。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
Dockerfile 链接GitHub 仓库: https://github.com/inotify-tools/inotify-tools
来自 Linux 手册页(<[***]>):
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可用标志的更多详情,请参见 https://github.com/inotify-tools/inotify-tools%E3%80%82布尔值可设置为任何值以被视为 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 秒后超时并重新设置监控器 |
Kubernetes
以下示例定义包含应用容器和 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
您可以使用以下命令拉取该镜像。请将 <标签> 替换为具体的标签版本。如需查看所有可用标签版本,请访问 标签列表页面。
来自真实用户的反馈,见证轩辕镜像的优质服务