项目背景
硬件架构采用Nginx
+ SLB
,应用程式使用 Laravel
的 .env
进行配置管理 ,随着业务的迭代越来越多的配置被写入 .env
文件,变得越来越臃肿,管理起来也不方便。
按照集群设计,支持分布式扩展,配置中心不可用要保证不影响业务,客户端使用Redis
+File
的方式保存配置
信息。
使用supervisor
守护进程,支持秒级获取配置,后续可扩展为消息订阅
。
架构图
基于composer开发扩展,配置中心
与客户端
通信基于RESTful
,系统拆分为2个composer,server
包 + client
包。
server
负责配置管理,client
负责API封装
UI界面
配置管理
数组支持用
.
号,支持键值使用json
接口数据
客户端请求接口,最终转被换成PHP数组。
表设计
多应用
CREATE TABLE `tms_configure_client` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`is_active` tinyint(1) NOT NULL DEFAULT '1' COMMENT '状态',
`app_id` varchar(32) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'APPID',
`title` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '名称',
`intro` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '描述',
`created_at` timestamp NULL DEFAULT NULL,
`updated_at` timestamp NULL DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `configure_client_app_id_index` (`app_id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
给每个应用分配一个APPID是很有必要的。
配置分组
CREATE TABLE `tms_configure_group` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`ip` varchar(30) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT 'ip地址',
`title` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '标题',
`intro` varchar(200) COLLATE utf8mb4_unicode_ci NOT NULL COMMENT '描述',
`created_at` timestamp NULL DEFAULT NULL,
`updated_at` timestamp NULL DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
暂时仅支持定义到APPID
+IP
级别配置
配置节点
CREATE TABLE `tms_configure_node` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT,
`app_id` bigint(20) unsigned NOT NULL COMMENT 'APPID',
`is_active` tinyint(3) unsigned NOT NULL DEFAULT '1',
`version_id` varchar(20) COLLATE utf8mb4_unicode_ci NOT NULL,
`group_id` bigint(20) unsigned NOT NULL,
`skey` varchar(50) COLLATE utf8mb4_unicode_ci NOT NULL,
`svalue` varchar(2000) COLLATE utf8mb4_unicode_ci NOT NULL,
`remark` varchar(50) COLLATE utf8mb4_unicode_ci DEFAULT NULL,
`created_at` timestamp NULL DEFAULT NULL,
`updated_at` timestamp NULL DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `idx_acitve` (`is_active`,`group_id`),
KEY `idx_skey` (`skey`),
KEY `configure_node_app_id_is_active_group_id_index` (`app_id`,`is_active`,`group_id`)
) ENGINE=InnoDB AUTO_INCREMENT=102 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
这里我们支持mysql.port
这种采用.
号key
的形式,后面最终转化为php
数组。
Composer包
服务端
{
"name": "xxx/xxx",
"type": "library",
"keywords": ["laravel","php","configure"],
"description": "configure-server module",
"homepage": "https://github.com/xxx",
"license": "MIT",
"authors": [
{
"name": "OkamiChen",
"email": "[email protected]"
}
],
"require": {
"php": ">=7.1.0"
},
"autoload": {
"psr-4": {
"OkamiChen\\ConfigureServer\\":"src/"
}
},
"extra": {
"laravel": {
"providers": [
"OkamiChen\\ConfigureServer\\ServerServiceProvider"
]
}
}
}
客户端
{
"name": "xxx/xxx",
"type": "library",
"keywords": ["laravel","php","configure"],
"description": "configure-client module",
"homepage": "https://github.com/xxx",
"license": "MIT",
"authors": [
{
"name": "OkamiChen",
"email": "[email protected]"
}
],
"require": {
"php": ">=7.1.0"
},
"autoload": {
"psr-4": {
"OkamiChen\\ConfigureClient\\":"src/"
},
"files": [
"src/helper.php"
]
},
"extra": {
"laravel": {
"providers": [
"OkamiChen\\ConfigureClient\\ClientServiceProvider"
]
}
}
}
结束语
今天先写到这里,后面开始coding工作。