您好,登錄后才能下訂單哦!
本篇文章為大家展示了在docker中使用ENTRYPOINT或CMD命令怎么啟動服務,內容簡明扼要并且容易理解,絕對能使你眼前一亮,通過這篇文章的詳細介紹希望你能有所收獲。
利用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中使用ENTRYPOINT或CMD命令怎么啟動服務,你們學到知識或技能了嗎?如果還想學到更多技能或者豐富自己的知識儲備,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。