docker 使用CMD或者ENTRYPOINT命令同时启动多个服务(docker compose)

admin 191 2022-07-23

阿里云服务器优惠多,折扣错,惊喜多,请咨询:www.wqiis.com

需求:django中引入了celery,当启动django项目时,如何将celery服务也启动

利用ENTRYPOINT命令启动

docker 使用CMD或者ENTRYPOINT命令同时启动多个服务(docker compose)

一、编写Dockerfile文件

FROM centos:7 RUN localedef -c -f UTF-8 -i zh_CN zh_CN.utf8 ENV LC_ALL zh_CN.UTF-8 COPY ./hrms $CODE_DIR/hrms/ COPY ./run $CODE_DIR/run/ RUN chmod a+x $CODE_DIR/run/* RUN pip3 install -r $CODE_DIR/hrms/requirements.txt EXPOSE 8080 WORKDIR /opt/hrms/hrms/

以上不用看,关键看下面这个命令

#启动一个服务用CMD即可 # CMD ["python3.5", "/opt/hrms/hrms/manage.py", "runserver", "0.0.0.0:8080"] #启动多个服务时,可以用CMD 执行一个脚本,在脚本中启动多个服务 CMD source /opt/hrms/run/entrypoint.sh #启动多个服务时,还可以用ENTRYPOINT执行一个脚本,在脚本中启动多个服务 ENTRYPOINT ["/opt/hrms/run/entrypoint.sh"]

CMD与ENTRYPOINT的区别就是CMD命令可以被docker-compose.yml文件中的command命令覆盖,一旦指定command,CMD命令就不再执行,而ENTRYPOINT永远不可被覆盖。

所以在这里我们可以这样:

用CMD启动一个脚本,然后脚本里启动多个服务,比如django、celery等,当你只想要做数据库迁移时,就可以在docker-compose.yml文件中的command中执行python manage.py migrate,这样CMD命令就不会被执行而仅仅执行数据库迁移。

二、entrypoint.sh脚本文件

#!/bin/bash #启动django python3.5 /opt/hrms/hrms/manage.py runserver 0.0.0.0:8080 & #启动worker celery worker -A celery_tasks.main -l info -f /opt/hrms/logs/celery.log & #这里注意日志位置要写绝对路径 #启动beat celery beat -A celery_tasks.main -l info

注意:前两个服务一定要在后台运行,即后面加个&,最后一个服务要以前台运行。

否则,全部以前台运行的话,只有第一个服务会启动;全部以后台运行的话,当最后一个服务执行完成后,容器就退出了。

补充知识:Dockerfile CMD的使用

CMD的三种格式:

CMD [“executable”,”param1”,”param2”] (exec form, 首选格式) CMD [“param1”,”param2”] (作为ENTRYPOINT的默认参数) CMD command param1 param2 (shell form)

注意事项:

上面的exec form是会被解析成一个JSON Array的,这意味着你必须使用双引号,而不是单引号。

exec form是不会调用命令行解释器的(command shell)。

比如CMD [ “echo”, “HOME"]中是不会对HOME做变量替换的。如果要是用到shell的话,应该这样:CMD [ “sh”, “-c”, “echo $HOME” ]

一个Dockfile中应该只有一个CMD,如果有多个,只会执行最后一个

格式使用的例子:

CMD [“sh”,”run.sh”]

或者

CMD sh run.sh

上一篇:域名查询是否注册,如何进行域名申请注册?
下一篇:商标注册45类明细中注册频率最高的商标类别是哪些
相关文章

 发表评论

暂时没有评论,来抢沙发吧~