合格的配置中心应有的素养No.76

最近在看配置中心的一些设计,好像基本都是五花八门,主要看的是还是携程的 Apollo 这个开源的配置中心项目。一直以来都觉得配置中心很重要,因为这对于灰度发布,线上实施干预都有非常重大的作用。但是嘛,你们都知道我有多懒,所以又一直没去好好了解一下,今天趁这个时间跟大家聊聊配置一个合格的配置中心应有的素养。

  1. 首先什么是配置?

  2. 配置有什么获取方式?

  3. 为什么需要实时变更配置?

  4. 为什么需要配置中心

  5. 配置中心的分层有必要吗?

  6. 实时变更配置的方式有几种?

  7. 配置中心还有什么其他基本的素养?

  8. 一个实时推送的配置中心架构是怎样的?

01、首先什么是配置?

我的理解是,配置是同一个程序在不同场景不同环境下做出不同表现的一个可变动频繁的点。配置在启动的时候通过各种形式进行获取,在整个生命流程中配置一般来说,是只读的,程序是不会主动去变更的,只有其他地方变更了之后才会触发程序的变更。

最经典的配置有两类,一类是数值型,比如客户的授信额度比例。一类是 Bool 型,用来对某些功能做禁用或启用。

public class configuration {

    private int NUMBER_CONFIG  = 5;
    private boolean SWITCH_CONFIG = true;

    public void config(){
        if(SWITCH_CONFIG){
            System.out.println("YES");
        }
        System.out.println("print YES" + NUMBER_CONFIG);
    }
}

02、配置有什么获取方式?

配置的获取方式不外乎5种。Hard Code、配置文件、环境变量、数据库获取、启动参数,外部 server 获取。

喇喇喇。上面我写的那堆玩意就是 Hard Code 的。什么叫 Hard Code,就是代码写得跟铁似的硬邦邦的你敲一下还会叮的一生那种。

配置文件,呐,平时用的比较多还是配置文件,比如 Spring 的 application.xml 啊,someFool.properties。

环境变量,嗯,比如 JAVA_HOME 之类的在操作系统上的环境变量。

数据库获取,就是启动的时候或者定时去数据库捞一下。

启动参数,就是作为启动的时候带的参数。比如 java -jar start.jar big。最后的 big 就是启动参数,也是配置项的一种。

外部 server 获取,意思就是这个配置项呢,是其他系统维护的,比如说存款准备金,就是一个央妈这个超级中心维护的配置项,所有的中小企业都要去央妈获取。

03、为什么需要实时变更配置?

人都是善变的,别问我为什么。。。老板昨天说咱有钱,就给客户爸爸们发钱吧,一单 15% 。今天发现银包撑不住了,跟我说大蕉同学我不管你怎么搞你赶紧把这个功能下了,我又不想发版本,所以就需要实时变更配置了。就这么简单,人都是善变的。

04、为什么需要配置中心?

一个应用两个应用还行,要是有100个应用,还真不知道怎么管理,实时推送配置项也成了一大难题。现在传统的比较主流的配置项管理做法有这么几种。

改代码重新打包(真特么傻逼)

改配置项重启。(说实话蛮那啥的)

改数据库重启。(一样)

改数据库定时获取。(浪费资源,一直在轮询,还需要一定时间才生效)

只能说,时间太长了,太浪费了,少则30秒多则60分钟(不要问我为什么是60分钟,因为有一些傻逼应用启动起来就特么要这么久)。

所以有个配置中心来帮你管理这些东西,不亦说乎?

05、配置中心的分层有必要吗?

现在主流的配置中心都会进行分层,五花八门,有的恨不得一台机器一台机器管理,有的又特么的一个集群只能统一配置。其实只需要下面几个维度就够了,应用维度,集群维度,机器维度。有了这三个维度基本可以满足99.9999%的需求,如果发现还不能满足,那么你所说的不在我这个范围。(偷笑ing)

06、实时变更配置的方式有几种?

从广义来说,就两种,一是定时拉取,而是实时推送。

定时拉取的有:定时从数据库拉取,定时从外部 server 拉取,定时从共享配置文件读取。

实时推送的有:用 kafka 等消息队列作为消费端消费,用 webSocket、 http 或者 rpc 接口 作为服务端接收推送。

07、配置中心还有什么其他基本的素养?

可分区推送

可以作为 A/B Test 的一种手段,也可以用来预防配置出错。

审批

一般来说配置变更是一件不小的事情,还是要有审批链的。

环境识别

对于 DEV 开发环境,STG 测试环境,PRD 生产环境要能做到针对环境不同读取不同的配置项。

持久化

有时候配置中心会挂了,而这时候是不应该影响应用的,所以应该要有持久化的机制来保证服务恢复后的数据问题。

监控

用户能实时知道发布到什么哪了,哪些机器是新配置哪些机器是旧配置,以及基于版本的实实时回滚功能。

操作审计

对配置的一切操作都会有操作记录,以便后期监控和审计用。

08、一个实时推送的配置中心架构是怎样的?

image

一个配置中心最朴素的架构就是上面这样。用户发布配置修改,配置中心通知应用进行更新,应用获取最新配置。

再细一点呢,分为客户端和配置中心两路来讲。

客户端

客户端在应用启动的同事,要启动一个服务专门用来接收来自配置中心的通知,这个服务可以是 kafka 、RocketMQ、WebSocket、RPC、DUBBO 等能作为服务提供给外部的接口,并主动向配置中心注册自己。

服务提供完之后,开始扫描自己所需要的配置项,并根据配置主动从本地读取(本地开发模式)或从配置中心获取相应环境的配置项。

读取完成后放在内存中,所有对于配置的读取都从内存中读取,对于JAVA来说可能就是一个 static 变量或者一个 HashMap 。

如果配置中心通知变更了,那么直接读取新的值,然后替换内存中的配置项,就 ok 了。

配置中心

配置中心要做的事情,就是根据用户的操作,对配置项进行发布,通过调用客户端提供的接口或者发送消息,通知客户端来更新消息,或者直接把更新的配置项推过去。非常朴素但是非常好用。

如果觉得还行的话点赞或者分享给朋友吧,当然能赞赏个一毛钱就更好了我都会很开心也欢迎留言告诉我大家希望看到些什么。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,497评论 18 139
  • 国家电网公司企业标准(Q/GDW)- 面向对象的用电信息数据交换协议 - 报批稿:20170802 前言: 排版 ...
    庭说阅读 10,800评论 6 13
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,050评论 25 707
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,678评论 6 342
  • 自古辞旧迎新总是阖家团聚幸福安乐的时刻。人们寄语未来,赋予它许多美好的祝愿和希望。求财源广进,求家庭和睦,求身体健...
    鱼鳅儿阅读 113评论 0 0