发布于2019-08-07 14:19 阅读(272) 评论(0) 点赞(0) 收藏(1)
利用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命令就不会被执行而仅仅执行数据库迁移。
有关两者更详细的区别请看我的另一篇文章。
#!/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
注意:前两个服务一定要在后台运行,即后面加个&,最后一个服务要以前台运行。
否则,全部以前台运行的话,只有第一个服务会启动;全部以后台运行的话,当最后一个服务执行完成后,容器就退出了。
作者:dgfv
链接:https://www.pythonheidong.com/blog/article/11321/21f87c5f3f1a4ca6ce73/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!