黑马程序员技术交流社区

标题: 【广州python】docker supervisord 管理多进程的建议 [打印本页]

作者: 唐伯虎(0)    时间: 2019-8-22 12:24
标题: 【广州python】docker supervisord 管理多进程的建议
本帖最后由 唐伯虎(0) 于 2019-8-22 12:28 编辑


配置使用绝对路径

启动参数 -c 指定配置 supervisord.conf 绝对路径。比如 Dockerfile 最后这么写:

ENTRYPOINT ["/usr/bin/supervisord", "-c", "/etc/supervisor/supervisord.conf"]
多个启动项配置文件统一目录

如 /etc/supervisor/conf.d/,并且在 supervisord.conf include 这里目录

[include]files = /etc/supervisor/conf.d/*.conf

每个启动项日志统一

统一放入目录,如:/tmp/xxx_stdout.log,并设置日志滚动大小和保留份数

supervisord 配置

[inet_http_server]

port=127.0.0.1:9001
username=user
password=123

[supervisorctl]
serverurl=http://127.0.0.1:9001
username=user
password=123

缺点就是多监听本地一个端口,并注意不能和应用端口冲突

一次性程序
比如要执行初始化,可以:

[program:xxx]
command=sh /xxx.sh
startretries=0
autorestart=false

传递环境变量
针对非 root 用户启动,并且需要读取容器启动时候环境变量(env)传递,新写 ENTRYPOINT 脚本中获取环境变量,写入文件,最后再运行 supervisord

$ cat Dockerfile
ENTRYPOINT ["/entrypoint.sh"]
$ cat /entrypoint.sh
# 获取环境变量,写入配置,或者拼接完整 command
/usr/bin/supervisord -c xx.conf

重启或者重加载配置
在容器内 kill -HUP 1 即可
-EOF-







欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2