本文关键详细介绍了docker 应用CMD或是ENTRYPOINT命令另外启动好几个服务,具备非常好的实用价值,期待对大伙儿有一定的协助。一起追随我回来瞧瞧吧
要求:django中导入了celery,当启动django新项目时,如何把celery服务也启动
运用ENTRYPOINT命令启动
一、撰写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
留意:前2个服务一定要在后台程序,即后边加个&,最后一个服务要之前台运作。
不然,所有之前台运作得话,仅有第一个服务会启动;所有以后台程序得话,当最后一个服务执行进行后,器皿就撤出了。
填补专业知识: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
之上这篇docker 应用CMD或是ENTRYPOINT命令另外启动好几个服务便是我共享给大伙儿的所有内容了,期待能给大伙儿一个参照,也期待大伙儿多多的适用大家。
热搜词