docker 使用CMD或者ENTRYPOINT命令同时启动多个服务
需求:django中引入了celery,当启动django项目时,如何将celery服务也启动
利用ENTRYPOINT命令启动
一、编写Dockerfile文件
FROMcentos:7 RUNlocaledef-c-fUTF-8-izh_CNzh_CN.utf8 ENVLC_ALLzh_CN.UTF-8 COPY./hrms$CODE_DIR/hrms/ COPY./run$CODE_DIR/run/ RUNchmoda+x$CODE_DIR/run/* RUNpip3install-r$CODE_DIR/hrms/requirements.txt EXPOSE8080 WORKDIR/opt/hrms/hrms/
以上不用看,关键看下面这个命令
#启动一个服务用CMD即可 #CMD["python3.5","/opt/hrms/hrms/manage.py","runserver","0.0.0.0:8080"] #启动多个服务时,可以用CMD执行一个脚本,在脚本中启动多个服务 CMDsource/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中执行pythonmanage.pymigrate,这样CMD命令就不会被执行而仅仅执行数据库迁移。
二、entrypoint.sh脚本文件
#!/bin/bash #启动django python3.5/opt/hrms/hrms/manage.pyrunserver0.0.0.0:8080& #启动worker celeryworker-Acelery_tasks.main-linfo-f/opt/hrms/logs/celery.log这里注意日志位置要写绝对路径 #启动beat celerybeat-Acelery_tasks.main-linfo
注意:前两个服务一定要在后台运行,即后面加个&,最后一个服务要以前台运行。
否则,全部以前台运行的话,只有第一个服务会启动;全部以后台运行的话,当最后一个服务执行完成后,容器就退出了。
补充知识:DockerfileCMD的使用
CMD的三种格式:
CMD[“executable”,”param1”,”param2”](execform,首选格式)
CMD[“param1”,”param2”](作为ENTRYPOINT的默认参数)
CMDcommandparam1param2(shellform)
注意事项:
上面的execform是会被解析成一个JSONArray的,这意味着你必须使用双引号,而不是单引号。
execform是不会调用命令行解释器的(commandshell)。
比如CMD[“echo”,“HOME"]中是不会对HOME做变量替换的。如果要是用到shell的话,应该这样:CMD[“sh”,“-c”,“echo$HOME”]
一个Dockfile中应该只有一个CMD,如果有多个,只会执行最后一个
格式使用的例子:
CMD[“sh”,”run.sh”]
或者
CMDshrun.sh
以上这篇docker使用CMD或者ENTRYPOINT命令同时启动多个服务就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。