服务器系统多个cmd,docker 使用CMD或者ENTRYPOINT命令同时启动多个服务

本文关键详细介绍了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命令另外启动好几个服务便是我共享给大伙儿的所有内容了,期待能给大伙儿一个参照,也期待大伙儿多多的适用大家。

热搜词

你可能感兴趣的:(服务器系统多个cmd)