分布式配置中心
XConf
基于 go-micro 构建的分布式配置中心,提供配置的管理与发布、实时推送.
.
├── LICENSE
├── README.md
├── admin-api // 配置管理 api 服务
├── agent-api // 配置获取,推送服务
├── client // micro config 客户端插件
├── config-srv // 配置管理服务
├── dashboard // 前端UI
├── doc
├── go.mod
├── go.sum
├── micro // micro api 网关
└── proto
线上 demo - http://xconf.mogutou.xyz/admin/ui
依赖
MySQL XConf 底层存储使用 mysql 数据库
CREATE DATABASE xconf
root:12345@(127.0.0.1:3306)/xconf?charset=utf8&parseTime=true&loc=Local
docker 快速启动 all in one
所有服务打包到一个容器中,仅仅作为快速预览使用,不可作为生产使用。
docker pull xuxu123/xconf-all:latest
docker run --name xconf -it --rm -p 8080:8080 -e BROADCAST=broker -e DATABASE_URL="root:12345@(IP地址:3306)/xconf?charset=utf8&parseTime=true&loc=Local" xuxu123/xconf-all
agent
agent 负责实时获取指定 应用/集群 下的所有配置文件到指定文件夹中
NAME:
agent - XConf agent client
USAGE:
main [global options] command [command options] [arguments...]
VERSION:
0.0.1
COMMANDS:
help, h Shows a list of commands or help for one command
GLOBAL OPTIONS:
--url value, -u value base url (default: "127.0.0.1:8080") [$XCONF_BASE_URL]
--app value, -a value app name [$XCONF_APP_NAME]
--cluster value, -c value cluster name [$XCONF_CLUSTER_NAME]
--dir value, -d value directory (default: "/tmp") [$XCONF_DIR]
--help, -h show help
--version, -v print the version
docker run --name agent -v /tmp/docker-xconf:/tmp -d xuxu123/agent -u http://xconf.mogutou.xyz -a test -c dev -d /tmp
Golang pkg/client/example
git clone https://github.com/micro-in-cn/XConf.git
cd XConf/pkg/client/example
go run main.go
客户端支持读取配置,实时获取配置更新(页面上"发布"操作才能触发配置推送,"保存"操作仅是保存配置)
XConf 参考了 Apollo 在业界成熟的设计方案。