是的,您可以通过两种方法来执行此 *** 作。
Docker撰写在Docker Compose中,您可以在文件本身中提供环境变量,也可以指向外部env文件:
# docker-compose.ymlversion: '2'services: service-name: image: service-app environment: - GREETING=hello env_file: - .env
顺便说一句,一个与之相关的不错的功能是,您可以使用多个Compose文件,随后的每个文件都添加到另一个文件中。因此,如果上面定义了一个基础,则可以执行此 *** 作(例如,针对每个运行时环境):
# docker-compose-dev.ymlversion: '2'services: service-name: environment: - GREETING=goodbye
然后可以运行它:
仅限Dockerdocker-compose -f docker-compose.yml -f docker-compose-dev.yml up
仅在Docker中执行此 *** 作,请使用入口点或命令来运行中间脚本,因此:
#Dockerfile....ENTRYPOINT ["sh", "bin/start.sh"]
然后在您的启动脚本中:
#!/bin/shsource .envpython /manager.py
过去,我已将此相关答案用作自己的参考。
PID 1更新为了进一步说明我的意见,如果将入口点设置为shell或Python脚本,则Unix信号(停止,终止等)很可能不会传递到您的进程中。这是因为该脚本将成为进程ID1,这使其成为容器中所有其他进程的父进程-在Linux /
Unix中,期望此PID将信号转发给其子进程,但是除非您明确实现,它不会发生。
要解决此问题,您可以安装一个初始化系统。我使用Yelp的dumb-init。如果您想更好地了解它,此版本库还具有很多详细信息,或者如果您只是想“安装后忘了”,则提供简单的安装说明。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)