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
注意:前兩個服務一定要在后臺運行,即后面加個&,最后一個服務要以前臺運行。
否則,全部以前臺運行的話,只有第一個服務會啟動;全部以后臺運行的話,當最后一個服務執行完成后,容器就退出了。
補充知識: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命令同時啟動多個服務就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。
相關文章: