国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 服務器 > Web服務器 > 正文

Docker Compose引用環境變量的方法示例

2024-09-01 13:56:13
字體:
來源:轉載
供稿:網友

在項目中,往往需要在 docker-compose.yml 文件中使用環境變量來控制不同的條件和使用場景。本文集中介紹 docker compose 引用環境變量的方式。

說明:本文的演示環境為 ubuntu 16.04。

Compose CLI 與環境變量

Compose CLI(compose command-line 即 docker-compose 程序)能夠識別名稱為 COMPOSE_PROJECT_NAME 和 COMPOSE_FILE 等環境變量(具體支持的環境變量請參考這里)。比如我們可以通過這兩個環境變量為 docker-compose 指定 project 的名稱和配置文件:

$ export COMPOSE_PROJECT_NAME=TestVar$ export COMPOSE_FILE=~/projects/composecounter/docker-compose.yml

Docker,Compose,引用環境變量

然后啟動應用,顯示的 project 名稱都是我們在環境變量中指定的:

Docker,Compose,引用環境變量

如果設置了環境變量的同時又指定了命令行選項,那么會應用命令行選項的設置:

$ docker-compose -p nickproject up -d

Docker,Compose,引用環境變量

在 compose file 中引用環境變量

我們還可以在 compose file 中直接引用環境變量,比如下面的 demo:

version: '3' services: web:  image: ${IMAGETAG}  ports:  - "5000:5000" redis:  image: "redis:alpine"

我們通過環境變量 ${IMAGETAG} 指定了 web 的鏡像,下面通過 export 的方式來為 compose 配置文件中的環境變量傳值:

Docker,Compose,引用環境變量

注意,如果對應的環境變量沒有被設置,那么 compose 就會把它替換為一個空字符串:

Docker,Compose,引用環境變量

碰到這種情況,我們可以在 compose 的配置文件中為該變量設置一個默認值:

version: '3'services: web: image: ${IMAGETAG:-defaultwebimage} ports:  - "5000:5000" redis: image: "redis:alpine"

這樣,如果沒有設置 IMAGETAG 變量,就會應用 defaultwebimage:

Docker,Compose,引用環境變量

除了這種方式,我們還可以通過后面將介紹的 .env 文件來為環境變量設置默認值。

把環境變量傳遞給容器

先來看一下在 compose file 中如何為容器設置環境變量:

web: environment: DEBUG: 1

compose file 中的 environment 節點用來為容器設置環境變量,上面的寫法等同于:

$ docker run -e DEBUG=1

要把當前 shell 環境變量的值傳遞給容器的環境變量也很簡單,去掉上面代碼中的賦值部分就可以了:

web: environment: DEBUG:

這種情況下,如果沒有在當前的 shell 中導出環境變量 DEBUG,compose file 中會把它解釋為 null:

Docker,Compose,引用環境變量

在試試導出環境變量 DEBUG 的情況:

$ export DEBUG=1

Docker,Compose,引用環境變量

這才是我們設計的正確的使用場景!

使用文件為容器設置多個環境變量

如果覺得通過 environment 為容器設置環境變量不夠過癮,我們還可以像 docker -run 的 --env-file 參數一樣通過文件為容器設置環境變量:

web: env_file: - web-variables.env

注意,web-variables.env 文件的路徑是相對于 docker-compose.yml 文件的相對路徑。上面的代碼效果與下面的代碼相同:

$ docker run --env-file=web-variables.env

web-variables.env 文件中可以定義一個或多個環境變量:

# define web container envAPPNAME=helloworldAUTHOR=Nick LiVERSION=1.0

檢查下結果:

Docker,Compose,引用環境變量

原來 compose 把 env_file 的設置翻譯成了 environment!

.env 文件

當我們在 docker-compose.yml 文件中引用了大量的環境變量時,對每個環境變量都設置默認值將是繁瑣的,并且也會影響 docker-compose.yml 簡潔程度。此時我們可以通過 .env 文件來為 docker-compose.yml 文件引用的所有環境變量設置默認值!
修改 docker-compose.yml 文件的內容如下:

version: '3'services: web: image: ${IMAGETAG}      environment:  APPNAME:  AUTHOR:  VERSION: ports:  - "5000:5000" redis: image: "redis:alpine"

然后在相同的目錄下創建 .env 文件,編輯其內容如下:

# define env var default value.IMAGETAG=defaultwebimageAPPNAME=default app nameAUTHOR=default author nameVERSION=default version is 1.0

檢查下結果,此時所有的環境變量都顯示為 .env 文件中定義的默認值:

Docker,Compose,引用環境變量

配置不同場景下的環境變量

從前面的部分中我們可以看到,docker compose 提供了足夠的靈活性來讓我們設置 docker-compose.yml 文件中引用的環境變量,它們的優先級如下:

  1. Compose file
  2. Shell environment variables
  3. Environment file
  4. Dockerfile
  5. Variable is not defined

首先,在 docker-compose.yml 文件中直接設置的值優先級是最高的。
然后是在當前 shell 中 export 的環境變量值。
接下來是在環境變量文件中定義的值。
再接下來是在 Dockerfile 中定義的值。
最后還沒有找到相關的環境變量就認為該環境變量沒有被定義。

根據上面的優先級定義,我們可以把不同場景下的環境變量定義在不同的 shell 腳本中并導出,然后在執行 docker-compose 命令前先執行 source 命令把 shell 腳本中定義的環境變量導出到當前的 shell 中。通過這樣的方式可以減少維護環境變量的地方,下面的例子中我們分別在 docker-compose.yml 文件所在的目錄創建 test.sh 和 prod.sh,test.sh 的內容如下:

#!/bin/bash# define env var default value.export IMAGETAG=web:v1export APPNAME=HelloWorldexport AUTHOR=Nick Liexport VERSION=1.0

prod.sh 的內容如下:

#!/bin/bash# define env var default value.export IMAGETAG=webpord:v1export APPNAME=HelloWorldProdexport AUTHOR=Nick Liexport VERSION=1.0LTS

在測試環境下,執行下面的命令:

$ source test.sh$ docker-compose config

Docker,Compose,引用環境變量

此時 docker-compose.yml 中的環境變量應用的都是測試環境相關的設置。

而在生產環境下,執行下面的命令:

$ source prod.sh$ docker-compose config

Docker,Compose,引用環境變量

此時 docker-compose.yml 中的環境變量應用的都是生產環境相關的設置。

總結

docker compose 對環境變量的使用提供了非常豐富支持和靈活的使用方式。希望通過本文的總結可以幫助大家理清相關的用法,并能夠以簡潔的方式為不同的使用場景提供支持。

參考:

Compose CLI environment variables
Environment variables in Compose
Compose file variable substitution
Declare default environment variables in file

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。


注:相關教程知識閱讀請移步到服務器教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 樟树市| 峡江县| 汉中市| 临澧县| 溆浦县| 亚东县| 柳江县| 乐业县| 安化县| 西吉县| 麻城市| 淮安市| 江油市| 屏山县| 弥渡县| 吉木萨尔县| 屏边| 达拉特旗| 出国| 高台县| 江永县| 东港市| 凤山市| 仙桃市| 大兴区| 荥阳市| 和顺县| SHOW| 高唐县| 法库县| 万盛区| 靖边县| 普格县| 铜梁县| 当涂县| 封开县| 崇信县| 沾化县| 濮阳县| 津市市| 班戈县|