首页 > 科技 > 正文

docker 使用CMD或者ENTRYPOINT命令1个容器里同时启动多个服务
2019-10-28 10:20:24   来源:东方头条   

利用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

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

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

相关热词搜索:多个 命令 启动 容器里 服务

上一篇:蜂窝通信模组产业崛起,国产份额提升
下一篇:最后一页

济宁知名律师   电话:0531-80961678
手机:18053115917   微信:18053115917   QQ:709581498   邮箱:709581498@qq.com
网站地图 (XML地图 / 百度地图