在预生产环境跑了一年多,在此记录和分享一下。php
当咱们须要在多台服务器部署多个不一样的项目时,咱们须要一个集中的配置信息管理和同步的工具。考虑过的方案有:html
.env
文件:多个项目的配置略繁琐,要ssh到服务器修改再同步下面看一下Consul + Consul Template的方案。git
Consul和Consul Template都提供了预编译的可执行文件,下载解压便可。github
启动Consul:json
consul agent -server -bootstrap -ui -bind <ip>
其余服务节点能够经过consul agent -join <ip>
加入到集群。bootstrap
启动以后经过consul命令、RESTful API、Web UI管理Consul。服务器
Consul提供了一个分布式的键值对存储,能够用来存储应用的动态配置信息,基本操做:app
# put 设置一个KV对 consul kv put APP_DEBUG false # get 获取 consul kv get APP_DEBUG # exprot 导出JSON consul kv export > data.json # import 导入JSON consul kv import @data.json # delete 删除 consul kv delete APP_DEBUG
Consul KV支持目录,能够经过/
分隔key实现,例如咱们使用configs/<app_name>/
这样的目录来存放一个项目的全部配置。ssh
配置集中管理了,怎样传给Laravel呢?一个方法是在Laravel里用Consul的API获取配置信息,第二个发放是在外部监听KV变化而后写入到.env
文件,Consul Template就是这样的一个外部工具。分布式
咱们用的配置模板(.env.tpl
):
{{ range ls "configs/crm" }} {{ .Key }}={{ .Value }}{{ end }}
意思是遍历config/crm
这个KV目录,生成key=value
格式。
运行:
## 格式: 模板文件:目标文件:更新后执行的命令 consul-template --template \ /path/to/.env.tpl:/path/to/.env:'php /path/to/artisan config:cache'
就能够生成.env文件,而且持续监听变化,一个consul-template实例能够有多个--template多个参数,能够为一台服务器上多个项目生成配置文件。