Laravel框架下的配置管理系统的设计过程(附代码)
本篇文章给大家带来的内容是关于Laravel框架下的配置管理系统的设计过程(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
项目背景
硬件架构采用Nginx + SLB,应用程式使用 Laravel 的 .env 进行配置管理 ,随着业务的迭代越来越多的配置被写入 .env 文件,变得越来越臃肿,管理起来也不方便。
按照集群设计,支持分布式扩展,配置中心不可用要保证不影响业务,客户端使用Redis + File的方式保存 配置 信息。
使用 supervisor 守护进程,支持秒级获取配置,后续可扩展为消息订阅。按照集群设计,支持分布式扩展,配置中心不可用要保证不影响业务,客户端使用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": { "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": "x25125x@126.com" } ], "require": { "php": ">=7.1.0" }, "autoload": { "psr-4": { "OkamiChen\\ConfigureClient\\":"src/" }, "files": [ "src/helper.php" ] }, "extra": { "laravel": { "providers": [ "OkamiChen\\ConfigureClient\\ClientServiceProvider" ] } } }
相关文章推荐:
Atas ialah kandungan terperinci Laravel框架下的配置管理系统的设计过程(附代码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Pengambilan Model Laraveleloquent: Mudah mendapatkan data pangkalan data Eloquentorm menyediakan cara ringkas dan mudah difahami untuk mengendalikan pangkalan data. Artikel ini akan memperkenalkan pelbagai teknik carian model fasih secara terperinci untuk membantu anda mendapatkan data dari pangkalan data dengan cekap. 1. Dapatkan semua rekod. Gunakan kaedah semua () untuk mendapatkan semua rekod dalam jadual pangkalan data: USEAPP \ MODELS \ POST; $ POSTS = POST :: SEMUA (); Ini akan mengembalikan koleksi. Anda boleh mengakses data menggunakan gelung foreach atau kaedah pengumpulan lain: foreach ($ postsas $ post) {echo $ post->

Masa depan PHP akan dicapai dengan menyesuaikan diri dengan trend teknologi baru dan memperkenalkan ciri -ciri inovatif: 1) menyesuaikan diri dengan pengkomputeran awan, kontena dan seni bina microservice, menyokong Docker dan Kubernetes; 2) memperkenalkan pengkompil JIT dan jenis penghitungan untuk meningkatkan prestasi dan kecekapan pemprosesan data; 3) Berterusan mengoptimumkan prestasi dan mempromosikan amalan terbaik.

PHP dan Python masing -masing mempunyai kelebihan sendiri, dan pilihannya harus berdasarkan keperluan projek. 1.Php sesuai untuk pembangunan web, dengan sintaks mudah dan kecekapan pelaksanaan yang tinggi. 2. Python sesuai untuk sains data dan pembelajaran mesin, dengan sintaks ringkas dan perpustakaan yang kaya.

Cecair memproses 7 juta rekod dan membuat peta interaktif dengan teknologi geospatial. Artikel ini meneroka cara memproses lebih dari 7 juta rekod menggunakan Laravel dan MySQL dan mengubahnya menjadi visualisasi peta interaktif. Keperluan Projek Cabaran Awal: Ekstrak Wawasan berharga menggunakan 7 juta rekod dalam pangkalan data MySQL. Ramai orang mula -mula mempertimbangkan bahasa pengaturcaraan, tetapi mengabaikan pangkalan data itu sendiri: Bolehkah ia memenuhi keperluan? Adakah penghijrahan data atau pelarasan struktur diperlukan? Bolehkah MySQL menahan beban data yang besar? Analisis awal: Penapis utama dan sifat perlu dikenalpasti. Selepas analisis, didapati bahawa hanya beberapa atribut yang berkaitan dengan penyelesaiannya. Kami mengesahkan kemungkinan penapis dan menetapkan beberapa sekatan untuk mengoptimumkan carian. Carian Peta Berdasarkan Bandar

PHP dan Python masing -masing mempunyai kelebihan mereka sendiri, dan memilih mengikut keperluan projek. 1.PHP sesuai untuk pembangunan web, terutamanya untuk pembangunan pesat dan penyelenggaraan laman web. 2. Python sesuai untuk sains data, pembelajaran mesin dan kecerdasan buatan, dengan sintaks ringkas dan sesuai untuk pemula.

PHP tetap penting dalam pembangunan web moden, terutamanya dalam pengurusan kandungan dan platform e-dagang. 1) PHP mempunyai ekosistem yang kaya dan sokongan rangka kerja yang kuat, seperti Laravel dan Symfony. 2) Pengoptimuman prestasi boleh dicapai melalui OPCACHE dan NGINX. 3) Php8.0 memperkenalkan pengkompil JIT untuk meningkatkan prestasi. 4) Aplikasi awan asli dikerahkan melalui Docker dan Kubernet untuk meningkatkan fleksibiliti dan skalabiliti.

Bagaimanakah Laravel memainkan peranan dalam logik backend? Ia memudahkan dan meningkatkan pembangunan backend melalui sistem penghalaan, eloquentorm, pengesahan dan kebenaran, acara dan pendengar, dan pengoptimuman prestasi. 1. Sistem penghalaan membolehkan definisi struktur URL dan logik pemprosesan permintaan. 2.eloquentorm memudahkan interaksi pangkalan data. 3. Sistem pengesahan dan kebenaran adalah mudah untuk pengurusan pengguna. 4. Acara dan pendengar melaksanakan struktur kod yang ditambah dengan longgar. 5. Pengoptimuman prestasi meningkatkan kecekapan aplikasi melalui caching dan beratur.

Sebab mengapa PHP adalah timbunan teknologi pilihan untuk banyak laman web termasuk kemudahan penggunaannya, sokongan komuniti yang kuat, dan penggunaan yang meluas. 1) Mudah dipelajari dan digunakan, sesuai untuk pemula. 2) Mempunyai komuniti pemaju yang besar dan sumber yang kaya. 3) Digunakan secara meluas dalam platform WordPress, Drupal dan lain -lain. 4) Mengintegrasikan dengan ketat dengan pelayan web untuk memudahkan penggunaan pembangunan.
