docker 利用CMD或者ENTRYPOINT命令同时启动多个服务 docker dockerfile 映射端口范围 批量映射端口

网友投稿 397 2022-10-25

docker 利用CMD或者ENTRYPOINT命令同时启动多个服务 docker dockerfile 映射端口范围 批量映射端口

以映射7000-8000端口为例 Dockerfile EXPOSE命令: EXPOSE 7000-8000 或Docker run命令: docker run --expose=7000-8000 或者,您可以通过Docker run命令将一系列端口发布到主机: docker run -p 7000-8000:7000-8000   需求: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 /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 注意:前两个服务一定要在后台运行,即后面加个&,最后一个服务要以前台运行。 否则,全部以前台运行的话,只有第一个服务会启动; 全部以后台运行的话,当最后一个服务执行完成后,容器就退出了。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:新款iPhone 11外形图曝光接口使用了闪电Lightning接口
下一篇:spring IOC容器管理必须知道的一些操作(基于XML方式)
相关文章

 发表评论

暂时没有评论,来抢沙发吧~