私が働いている会社では、私たちは別のルートを取りました。
ランタイム構成を受け入れるために Symfony と戦う代わりに (たとえば、Spring Data Consul のようにすべきこと)、Consul が Symfony の構成を更新するようにすることにしました。これは、Frank が行ったのとは概念が似ていて、実装が異なります。
Consul と Consul Template をインストールしました。parameters.yml ファイル全体を含む K/V エントリ ペアを作成します。例:
鍵:eblock/config/parameters.yml
parameters:
router.request_context.host: dev.eblock.ca
router.request_context.scheme: http
router.request_context.base_url: /
次に、consul テンプレート構成ファイルが/opt/consul-template/config/eblock.cfg
次の場所に追加されました。
template {
source = "/opt/consul-template/templates/eblock-parameters.yml.ctmpl"
destination = "/var/www/eblock/app/config/parameters.yml"
command = "/opt/eblock/scripts/parameters_updated.sh"
}
ctmpl ファイルの内容は次のとおりです。
{{key "eblock/config/parameters.yml"}}
最後に、parameters_updated.sh
スクリプトは次のことを行います。
#!/bin/bash
readonly PROGNAME=$(basename "$0")
readonly LOCKFILE_DIR=/tmp
readonly LOCK_FD=201
lock() {
local prefix=$1
local fd=${2:-$LOCK_FD}
local lock_file=$LOCKFILE_DIR/$prefix.lock
# create lock file
eval "exec $fd>$lock_file"
# acquire the lock
flock -n $fd \
&& return 0 \
|| return 1
}
lock $PROGNAME || exit 0
export HOME=/root
logger "Starting composer install" && \
/usr/local/bin/composer install -d=/var/www/eblock/ --no-interaction && \
logger "Running composer dump-autoload" && \
/usr/local/bin/composer dump-autoload -d=/var/www/eblock/--optimize && \
logger "Running app/console c:c/c:w" && \
/usr/bin/php /var/www/eblock/app/console c:c -e=prod --no-warmup && \
/usr/bin/php /var/www/eblock/app/console c:w -e=prod && \
logger "Running doctrine commands" && \
/usr/bin/php /var/www/eblock/app/console doctrine:database:create --env=prod --if-not-exists && \
/usr/bin/php /var/www/eblock/app/console doctrine:migrations:migrate -n --env=prod && \
logger "Restarting php-fpm" && \
/bin/systemctl restart php-fpm &
consul と consul-template サービスの両方が起動していることがわかれば、consul テンプレートの指定されたキーで値が変更されるとすぐに、構成された宛先にファイルがダンプされ、更新されたパラメーターのコマンドが実行されます。
それは魅力のように機能します。=)