当我们谈配置中心时在谈什么

存在即合理,为什么需要配置中心

为什么需要配置中心,搭建一套服务管理配置有必要吗?配置放在配置文件或者数据库它不香吗?不是应该做减法吗?

  • 随着程序功能的日益复杂,程序的配置日益增多:各种功能的开关、参数的配置、服务器的地址等等
  • 一套系统需要配置多个环境,我们有开发环境,测试环境,预上线环境,线上环境,如何统一管理
  • 对配置的期望也越来越高,配置修改后实时生效,灰度发布,分环境、分集群管理配置,完善的权限、审核机制等等
  • 随着采用分布式的开发模式,项目之间的相互引用随着服务的不断增多,相互之间的调用复杂度成指数升高,每次投产或者上线新的项目时苦不堪言,因此需要引用配置中心治理

成熟的配置中心产品对比

配置中心对比

我们着重来看下nacos,这是阿里开源的新的一款配置中心(原来的配置中心为diamond,现在已经不维护了),下面看下它的架构设计:


nacos基本架构

再看下nacos的逻辑架构及组件:


nacos组件

除去Naming Service服务发现组件,我们讲一讲今天的重点配置模块,其中最主要的是三个模块:
1、配置服务:实现配置CRUD,版本管理,灰度管理,监听管理,推送轨迹,聚合数据等功能

2、注册中心:用于服务管理,配置变更通知等等;
3、客户端:提供配置获取、注册服务等;

ok,那下面我们就自己手动设计一个简单的配置中心。

整体设计图

整体设计图

特征

具备统一的管理配置能力、配置发布回滚能力、配置更新秒级推送能力、客户端配置缓存能力、对敏感配置设置访问权限能力、配置灰度发布能力、管理员权限管理能力。

  • 统一的管理配置能力:提供配置管理页面,可管理不同应用在不同环境中的配置。
  • 配置发布回滚能力:配置可一按照版本进行发布回滚。
  • 配置更新秒级推送能力:新配置发布后可秒级的推送到应用。
  • 客户端配置缓存能力:如果应用启动时无法连接服务端,可使用预先- 存储在缓存文件中的配置,保证应用正常启动。
  • 对敏感配置设置访问权限能力:可对一些重要或敏感的配置设置访问权限,防止配置被泄漏。
  • 配置灰度发布能力:满足各种配置灰度发布场景(传统部署方式、容器化部署方式、多重配置灰度发布等)。
  • 管理员权限管理能力:可对不同管理员设置对应的配置管理权限,让合适的人管理合适的配置。

角色

configcenter中的角色包含:服务端、客户端、MySQL数据库、Redis、Nginx、应用、配置管理员

  • 服务端--服务端用于集中管理应用的配置。配置数据落地到MySQL数据库,允许客户端通过http请求查询配置,允许客户端通过Http Long Polling(长轮询)接收配置变更通知。当应用的配置有了变更(增删改),则会通知客户端(秒级)。
  • 客户端--客户端用于协助应用获取配置。客户端刚启动时会通过http请求服务端读取应用的最新配置。如果从服务端读取失败,则客户端会尝试从本地缓存文件中读取配置;如果本地无缓存文件,则启动失败。客户端启动成功后,会通过Http Long Polling(长轮询)接收服务端配置变更通知。当监听到配置有变更时,客户端会再次通过http请求服务端读取最新配置,然后把最新配置保存到缓存文件,最后将最新配置和当前客户端中旧配置进行比较,将变化部分通知给应用。
  • MySQL数据库--MySQL数据库用于存储服务端管理的配置。
  • Redis--Redis有两个作用:1、缓存数据库存储的配置,提高系统响应效率;2、存储管理员登录的session;
  • Nginx--Nginx用于对多个服务端进行负载均衡。由于服务端使用Redis存储所有的管理员登录的session,所以Nginx的负载均衡策略可以使用随机策略,而不需要使用根据sessionId的策略。如果你有其他更好的负载均衡器,只要它能支持http协议,则完全可以使用它替代Nginx。
    应用--应用是从服务端获取配置的系统。应用可以通过客户端的协助获取配置;当然它也可以抛弃客户端,自己直接发起http请求服务端,获取配置。
  • 配置管理员--配置管理员管理配置,分为两个级别:普通管理员、超级管理员。普通管理员只能管理分配给他的配置;超级管理员既能管理所有配置,也能管理其他管理员。管理员可以是运维人员,也可以是开发人员。给开发人员分配相应的权限,让其可以自助的管理配置,提高工作效率。

设计的原则

  • 简约--从架构设计、服务端设计、客户端设计、数据库设计到页面设计,都遵从这个原则。
  • 部署简单--只依赖MySQL和Redis,部署时只需一个jar包+MySQL+Redis。
  • 配置治理--具有完善权限管理并且支持标记敏感配置,让你可以把非敏感配置放权给开发人员,让他们自助的管理配置,提高工作效率。
  • 配置共享--支持应用、环境两个纬度的继承关系(配置共享),让你可以去设计你的配置,让它变得优雅易管理。从开发的角度来看,就像从面向过程开发迈入面向对象开发一样。
  • 灰度发布--满足各种配置灰度发布场景(传统部署方式、容器化部署方式、多重配置灰度发布等)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,076评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,658评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,732评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,493评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,591评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,598评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,601评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,348评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,797评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,114评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,278评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,953评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,585评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,202评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,442评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,180评论 2 367
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,139评论 2 352

推荐阅读更多精彩内容