摘要:項目背景硬件架構采用,應用程式使用的進行配置管理隨著業務的迭代越來越多的配置被寫入文件,變得越來越臃腫,管理起來也不方便。使用守護進程,支持秒級獲取配置,后續可擴展為消息訂閱。架構圖基于開發擴展,配置中心與客戶端通信基于系統拆分為個,包包。
項目背景
硬件架構采用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": "x25125x@126.com" } ], "require": { "php": ">=7.1.0" }, "autoload": { "psr-4": { "OkamiChenConfigureServer":"src/" } }, "extra": { "laravel": { "providers": [ "OkamiChenConfigureServerServerServiceProvider" ] } } }客戶端
{ "name": "xxx/xxx", "type": "library", "keywords": ["laravel","php","configure"], "description": "configure-client module", "homepage": "https://github.com/xxx", "license": "MIT", "authors": [ { "name": "OkamiChen", "email": "x25125x@126.com" } ], "require": { "php": ">=7.1.0" }, "autoload": { "psr-4": { "OkamiChenConfigureClient":"src/" }, "files": [ "src/helper.php" ] }, "extra": { "laravel": { "providers": [ "OkamiChenConfigureClientClientServiceProvider" ] } } }結束語
今天先寫到這里,后面開始coding工作。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/29181.html
摘要:年,由北京的團隊開發了涉足社交開源行業。終于,在年下半年,我們決定重寫這個程序,拋棄之前的每一行代碼。起初,我們選擇在中做生成函數,配合第三方包實現,功能實現了。的拓展不能直接以這種方式使用喲,因為我們做這個的想法是把配置移交到后臺配置。 什么是 ThinkSNS+ 好吧,這不是廣告。。。在 09 年,由北京的團隊開發了 ThinkSNS 涉足社交開源行業。09 年,由北京的團隊開發了...
摘要:最簡化權限管理系統,基于開發。基于開發,唯一優化的是用權限和路由別名綁定,這樣代碼寫好之后就可以直接使用。如果是超級管理員,即使沒有這個權限會自動賦予權限給超級管理員角色。默認管理員賬號密碼。然后正常執行命令其他命令即可。 Any 最簡化權限管理系統,基于 Laravel5.4 開發。由于 Laravel5.5 發布推遲,只好先寫個 Laravel5.4版本的,后面再升級上去。演示地址...
摘要:設計判斷是否有某個權限是一個二維數組全局設置在數據庫中,我將二維數組存儲為,利用的的和方法,完成了數據庫中和外界程序邏輯的連接。 關于權限管理的思考最近用laravel設計后臺,后臺需要有個權限管理。權限管理實質上分為兩個部分,首先是認證,然后是權限。認證部分非常好做,就是管理員登錄,記錄session。這個laravel中也有自帶Auth來實現這個。最麻煩就是權限認證。 權限認證本質...
摘要:介紹在開發后臺接口現在更多的企業選擇了來開發后臺接口當然和不失為是一種不錯的選擇不過這里就以為例基于框架開發后臺這里也是如果你是從事其他方向想做一些后臺開發都可以去嘗試一下的當然實例項目我會不放在我的上僅供參考地址前期準備當然前提是安裝 介紹 在開發后臺接口現在更多的企業選擇了PHP來開發后臺接口 當然Python和NodeJs不失為是一種不錯的選擇 不過這里就以PHP為例 基于Lar...
閱讀 3478·2023-04-26 02:00
閱讀 3078·2021-11-22 13:54
閱讀 1699·2021-08-03 14:03
閱讀 709·2019-08-30 15:52
閱讀 3085·2019-08-29 12:30
閱讀 2420·2019-08-26 13:35
閱讀 3364·2019-08-26 13:25
閱讀 3001·2019-08-26 11:39