在我工作的公司中,我们采取了不同的方法。与其像Spring Data Consul那样与Symfony抗争接受运行时配置(它本应该这样做),我们决定让Consul更新Symfony配置,这与Frank的概念类似,但实现方式不同。
我们安装了Consul和Consul Template。我们创建了一个K/V条目对,其中包含整个parameters.yml文件。例如:
键:
eblock/config/parameters.yml
parameters:
router.request_context.host: dev.eblock.ca
router.request_context.scheme: http
router.request_context.base_url: /
然后在位置 /opt/consul-template/config/eblock.cfg
添加了一个Consul模板配置文件:
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"
}
< p > 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
eval "exec $fd>$lock_file"
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 模板的指定键中更改值后,它将将文件转储到配置的目标并运行更新参数的命令。
它工作得非常好。 =)