给测试小姐姐讲RPC——注册中心

看了柳大神的《如可给老婆解释什么是rpc》《如何实现一个简单的RPC》之后,我按这个思路给我们的测试小姐姐解释了什么是RPC,测试小姐姐毕竟是有功底的人,一下子就明白了

测试:“哦!RPC就是让服务的使用方像调用本地接口一样调用远程服务是吧”

me:“完全正确”

测试:“明白了,那zk是干什么的,我们公司用RPC的时候老是提到ZK”

me:“ZK啊,ZK是个注册中心”

测试:“哦?注册中心是什么吖?为什么要用注册中心吖?怎么用注册中心吖?”

me:“你这哲学三问打头,我有点招架不住啊,我理一理思路”

测试:“你说”

me:“上一集讲RPC的时候,我们是把被调用的服务的IP和端口写死的。但是这样并不好,如果有一天我们需要加机器了,我们还要重新修改IP和端口,然后重新发布”

测试:“你之前不是搞了个配置中心么,把ip和端口配到配置中心写成个list,调用的时候从list里面随便挑一个,地址换了改一下配置中心就好了啊”

me:“真机智,其实我觉得这已经算是一个不可靠的注册中心的原型了,能在服务启动的时候进行注册,服务停止的时候删除,然后让服务调用方可以查询服务的注册信息,也就是所谓【服务注册与发现】

测试:“不可靠?”

me:“你想啊,要是我们有一台提供服务的机器大半夜突然挂掉了。。。”

测试:“是啊,那该怎么办呢,要是能知道哪台机器能用哪台机器不能用就好了,我们只用那些可以用的机器”

me:“赞!这就涉及到注册中心的一个重要特点了,【错误转移】当某个服务提供者异常时,能及时删除注册信息。一般注册中心会定时发送心跳包,来检测服务提供方是否在线,并及时删除下线节点”

测试:“这样啊,那我们直接在调用方这么做不就好了,调用一台机器失败了,就访问下一台,一直到成功为止”

me:“好办法,那如果某一台机器死掉了,那我们每次调用的时候都有几率会失败,这很浪费时间啊。要是我们把死掉机器记录下来不再调用,那如果这台机器过一会重启了,我们也还是不会去请求他,这样会很浪费资源的”

测试:“是哦,可是你的服务重启了,注册中心也不知道啊”

me:“好问题,这又涉及到注册中心的另一个特点,当某个服务启动时,可以重新注册到注册中心上

测试:“明白了,所以注册中心的作用就是,当服务启动的时候把服务的ip和端口注册上去,服务异常的时候注册中心就把这台机器的注册信息删除掉,然后请求方只需要每次调用的时候去注册中心拿服务的注册信息再调用就可以了,对吧”

me:“差不多是这样了,但是还有个问题,你想想,要是你的服务提供者都是正常的,但是注册中心突然挂了,那怎么办,全公司的服务都没法请求了”

测试:“这个好说,本地缓存一份注册信息,每次从本地缓存来取,然后定时更新缓存”

me:“这也是个办法,不过一般的缓存更新不会采用轮询的方式,而是通过通知的方式,客户端与注册中心建立一个长连接,并注册一个监听器,服务注册信息发生变化的时候通知服务调用方更新注册信息,这样做既能及时更新信息,又能减少频繁访问带来的网络开销”

小姐姐画的注册中心图解

Tips(注册中心讲解过程中的一些支线交流)

负载均衡

有多台机器提供服务的时候注册中心怎么做LB呢(这是个优秀的测试小姐姐,她自己在公司分享过Nginx)

  • 其实负载均衡不是注册中心的事情,这个事情应该交给RPC框架,或者说是RPC的调用方去完成

轮询和心跳

轮询和心跳的区别,简单列一下

  1. 轮询往往由客户端发起,向服务端请求数据,而心跳则可以由客户端发起,也可由服务端发起
  2. 轮询每次请求需要重新建立连接,而心跳通常会保持一个TCP连接来完成,所以轮询的开销更大
  3. 轮询往往希望请求数据,而心跳则仅仅为了保持连接

轮询和监听

为什么使用长连接监听而不是轮询的方式来进行服务注册信息的更新呢

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

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,912评论 2 89
  • RPC注册中心-- 检测服务是否存活=注册中心的职责,发现服务,监控服务变更状态、健康检查。 需要做到的是:总能通...
    消失er阅读 3,183评论 0 3
  • 一、微服务介绍 1. 什么是微服务 在介绍微服务时,首先得先理解什么是微服务,顾名思义,微服务得从两个方面去理解,...
    阿南的生活记录阅读 441评论 0 3
  • □读宇宙 先生慢(66) □ 王红娟 悠悠洪昌先生, 独自行在温岭, 伊人独往? 悠悠教学梦,一场梦? ...
    朝花夕拾杯中酒123阅读 231评论 0 11