docker compose 中控制啟動(dòng)順序
docker compose 能夠根據(jù)服務(wù)的依賴來(lái)決定啟動(dòng)順序,比如可以強(qiáng)制通過(guò)depends_on
指定依賴刃泡。但是有些服務(wù)啟動(dòng)時(shí)間較長(zhǎng),比如數(shù)據(jù)庫(kù)叨橱,僅僅”啟動(dòng)“不代表服務(wù)可以用攻谁,最終可能會(huì)導(dǎo)致依賴它的服務(wù)啟動(dòng)失敗。
官方提供一個(gè)解決思路轧叽,就是把相關(guān)的啟動(dòng)命令做一層封裝苗沧,執(zhí)行其依賴服務(wù)是否已經(jīng)成功可用刊棕,再啟動(dòng)相應(yīng)的服務(wù)。
#!/bin/sh
# wait-for-postgres.sh
set -e
host="$1"
shift
cmd="$@"
until PGPASSWORD=$POSTGRES_PASSWORD psql -h "$host" -U "postgres" -c '\q'; do
>&2 echo "Postgres is unavailable - sleeping"
sleep 1
done
>&2 echo "Postgres is up - executing command"
exec $cmd
啟動(dòng)命令用以下命令覆蓋:
command: ["./wait-for-postgres.sh", "db", "python", "app.py"]
https://docs.docker.com/compose/startup-order/
通過(guò)環(huán)境變量配置參數(shù)
12-factor 最佳實(shí)踐推薦通過(guò)環(huán)境變量實(shí)現(xiàn)參數(shù)的配置待逞。
然而實(shí)踐中常常遇到以下問(wèn)題:
- 如果沒(méi)有相關(guān)配置文件鞠绰,使用者很難知道要提供哪些環(huán)境變量。
- 如果有配置文件飒焦,并推送到遠(yuǎn)程分支蜈膨,一方面存在泄漏密碼的風(fēng)險(xiǎn),而且實(shí)際運(yùn)行時(shí)往往需要改動(dòng)配置文件牺荠,才能正確運(yùn)行程序翁巍。
- 如果每次都使用環(huán)境變量來(lái)進(jìn)行測(cè)試驗(yàn)證,使用體驗(yàn)上比使用配置文件要麻煩休雌。
下面提供一個(gè)我實(shí)踐的思路灶壶。
- 提供配置文件,但配置參數(shù)全部使用本地測(cè)試數(shù)據(jù)杈曲。例如一個(gè)
config.py
文件驰凛,內(nèi)容如下:
db_name = 'my_db'
db_addr = '127.0.0.1'
db_passwd = 'my_passwd'
# 將環(huán)境變量替換本地變量
import os
config = globals()
for v_name, v_value in config.items():
if v_name not in os.environ:
continue
v_type = type(v_value)
config[v_name] = v_type(environ[v_name])
# 引入外部變量
if os.path.exists('env.py'):
from env import *
這樣可以在不改動(dòng)config.py
情況下,通過(guò)環(huán)境變量担扑,或者填充env.py
來(lái)實(shí)現(xiàn)覆蓋原有的config.py
文件恰响。這樣通過(guò)環(huán)境變量和固定的配置文件都可以覆蓋原有的配置文件,而不需要改變?cè)械?code>config.py文件涌献。
提示:如果使用 git 管理分支胚宦,可以通過(guò).gitignore
文件添加env.py
忽略掉這個(gè)文件的上傳。