每个DockerfileRUN
步骤都运行一个新的容器和一个新的shell。如果尝试在一个shell中设置环境变量,则以后将看不到该变量。例如,您可以尝试以下Dockerfile:
FROM busy@R_900_2419@
ENV FOO=foo1
RUN export FOO=foo2
RUN export BAR=bar
CMD echo FOO is $FOO, BAR is $BAR
# Prints "FOO is foo1, BAR is "
有三个好的解决方案。从最容易/最好到最难/最复杂:
将软件安装到“系统”位置,例如/usr
; 无论如何,它将被隔离在Docker映像中。(不要使用其他隔离工具(例如Python虚拟环境)或版本管理器(例如nvm
或rvm
;),只需安装所需的特定工具即可。)
这 将 起作用:
FROM busy@R_900_2419@
ENV FOO=foo2
ENV BAR=bar
CMD echo FOO is $FOO, BAR is $BAR
# Prints "FOO is foo2, BAR is bar"
#!/bin/sh
# Read in the file of environment settings
. /opt/wherever/env
# Then run the CMD
exec "$@"
COPY
将此脚本放入您的Dockerfile中。使之成为ENTRYPOINT
; 使它CMD
成为您实际正在运行的东西。
FROM busy@R_900_2419@
WORKDIR /app
COPY entrypoint.sh .
COPY more_stuff .
ENTRYPOINT ["/app/entrypoint.sh"]
CMD ["/app/more_stuff/my_app"]
如果你关心这样的事情,环境变量,你通过这种方式设置将不可见docker inspect
或docker exec
调试环境; 但是,如果您dockerrun-it...sh
将它们可见。这是一个有用且足够重要的模式,CMD
除非我专门尝试进行此类初次设置,否则我几乎总是在Dockerfile中使用它。