Docker 有没有官方的 Hook 机制,容器启动时可触发主机运行脚本?

2023-08-29 23:07:34 +08:00
 einsdisp

需要针对每一个容器设置 iptables 防火墙规则,在一个 container 启动后,触发主机上(不是容器内部)一个脚本运行,设置针对本容器的 iptables 规则,在 container 关闭后,再次触发主机上一个脚本运行,清理前一个脚本运行所产生的作用。

类似 systemd 的 ExecStartPost 、ExecStartPre 的机制,libvirt 也有类似机制(/etc/libvirt/hooks/qemu.d )

但是网上简单搜了下,docker 原生似乎不存在这种机制?这种常见的功能都没有,docker 不会这么弱吗?

2090 次点击
所在节点    程序员
11 条回复
yumusb
2023-08-29 23:12:23 +08:00
DockerFile ENTRYPOINT 关键字
einsdisp
2023-08-29 23:13:38 +08:00
@yumusb 那玩意是运行在容器里面的
ETiV
2023-08-29 23:28:46 +08:00
LeoYoung07
2023-08-30 00:24:43 +08:00
@ETiV 学习了,看起来可以通过类似这种方式实现:
https://stackoverflow.com/a/58289989
ETiV
2023-08-30 00:52:09 +08:00
对 ,管道给 while read

saltstack events 也可以这么干
Jirajine
2023-08-30 00:56:05 +08:00
你可以换 podman
JohnSwit
2023-08-30 08:55:46 +08:00
为啥一定要用 Docker 的机制?
直接写一个脚本不就好了
MuSit
2023-08-30 11:55:43 +08:00
上 k8s 用 operator 实现
MuSit
2023-08-30 11:57:09 +08:00
其实主要是要有个控制器能解析 container 生命周期事件 其他都好搞
williamx
2023-08-30 11:57:59 +08:00
这个一般我用脚本来控制容器启动,而不是直接用原始命令
ensonmj
2023-08-30 22:54:53 +08:00
runc 的配置里面是有 hook 的,不过好像不是用户可见的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/969327

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX