【docker】环境变量 和 脚本 作用
docker的作用是提供应用的隔离环境,方便部署。dockerfile有env选项,可以让我们在生成的镜像里添加一些环境变量,这些环境变量有什么作用?可以用来作为标志,代表部署的环境的一些参数。比如说我们需要一个docker部署一个mysql。那么我们可以添加一个标识来表示这个mysql是以什么方式启动的,比如说可以通过集群方式启动,也可以通过单机方式启动,很显然这两种模式的启
docker的作用是提供应用的隔离环境,方便部署。
dockerfile有env选项,可以让我们在生成的镜像里添加一些环境变量,这些环境变量有什么作用?
可以用来作为标志,代表部署的环境的一些参数。
比如说我们需要一个docker部署一个mysql。那么我们可以添加一个标识来表示这个mysql是以什么方式启动的,比如说可以通过集群方式启动,也可以通过单机方式启动,很显然这两种模式的启动命令是不同的。
那么我们可以使用dockerfile的env来实现这个自动化启动应用的过程。
比如说,我们可以在dockerfile里面提供一个默认的env,值是non-cluster,表示默认启动方式是单机版。
这样,我们在run一个容器的时候,如果不覆盖这个参数,那么环境变量就是non-cluster。相反,我们可以通过run的-e参数或者docker-compose的environment来覆盖这个参数为cluster,这时启动的容器里的环境变量就是cluster了。
这就是环境变量的作用,我们可以在运行一个容器的时候来指定容器的环境变量,以代表不同的启动参数。
但是光有这个环境变量并没有什么卵用,因为它只是一个变量或者标识而已,进一步的我们需要一个shell脚本来读取环境变量,以判断我们的启动方式,从而运行相应的命令。这个脚本可以通过add命令添加到容器内,然后使用cmd或者entrypoint来运行。
所以个人感觉,通过环境变量+启动脚本的方式可以最大限度的实现部署应用的自动化。真正的启动过程命令就在脚本里面,脚本会读到我们设置的环境变量。
一个小例子:
dockerfile:
FROM ubuntu:latest
ADD ./run.sh /
RUN chmod 777 /run.sh
CMD ["/run.sh"]
version: '3.2'
services:
app1:
image: test-env
environment:
- E1=10
run.sh:
#!/bin/bash
if [ $E1 -lt 100 ]
then
echo "yes"
else
echo "no"
fi
通过传递不同的E1,来判断输出内容。
更多推荐
所有评论(0)