真香定律!四面阿里拿offer面经分享,面试资料分享

野性酷女 2021-07-20 19:12 543阅读 0赞

重要

大环境对于我们能力要求越来越高,医学专家又说今年冬天新冠肺炎将“席卷重来”。

如果疫情再次爆发,势必将再次影响企业的正常运作,一波裁员浪潮你又能否抗住?

不管如何,明年金三银四又是一波跳槽时机,也该趁着这个时间开始提升一下自己的技术了。

不多说,十余位互联网一线大厂的大牛联合手写的Java高级知识,直接手撕面试官。

36aff0a4ac41726237da95792f03dc15.png

一、服务发布简介

分布式系统架构下,服务发布是一件很麻烦的事情,特别是在构建自动发布流程和灰度测试的策略两个核心方面。通常情况下如果不涉及数据层面的灰度流程,服务可以灰度上线,或者滚动上线,这两种方式很常用;如果涉及到数据灰度,则可能需要中间服务做不同版本数据之间追平,或者停机维护一次性处理好数据和上线问题,不过后面这种方式风险较大。

二、蓝绿部署

cd135376b17c1c1fe44d0060ed2d9961.png

新版本上线的时候,并不停掉老版本,新旧两个版本同时运行,通常还会在负载均衡的策略上倾向于旧版本服务处理请求,这样新版本就有一个执行的观察期过渡期,等到新版本平稳运行一段时间后,再把请求都发到新版服务上,旧版本服务完成下线。这种方式在分布式架构下很少使用,对服务器要求过高。

三、滚动发布

02f329912a7e68cf49e5499dcf6d2b3d.png

滚动发布可以避免蓝绿部署的服务器资源占用问,首先发布一台新版本服务,然后停掉一台老版本服务,新版服务经过观察之后,再逐步替换掉所有老版本的服务,这样服务的环境变动比较频繁,相对不稳定。

四、灰度发布

上述两种方式在普通业务场景下都还算好操作,分布式系统下的灰度发布复杂程序相对高很多,基础流程如下:

f3b00188f671bb7ecd79f093237799b0.png

新版本上线,可能涉及分布式下多个灰度服务,因此在服务在整个链路上分发时,都要判断下个请求是路由到正常服务还是灰度服务,还要对灰度服务做请求的权重控制,不能让灰度服务处理大量的请求。

实际策略:在实际的分布式系统灰度发布流程,通常会采用如下一个策略:

  • 配置一个灰度是否开启的标识;
  • 配置一批灰度账户,通常内部人员;
  • 配置灰度服务版本标识;
  • 请求在链路执行时,判断灰度是否开启;
  • 判断当前用户身份是否是灰度测试账号;
  • 获取当前可以请求的服务列表;
  • 根据灰度服务版本选择请求的具体服务;

这个流程非常的复杂,需要很多自定义的策略,还要熟悉分布式框架的底层API原理,要二次重写来适配灰度策略,设计重写原生API还容易触发一些惊喜问题。

五、数据库灰度

如果说最难处理的灰度模式是什么,就是数据库的版本灰度问题,通常业务对数据库改造升级,实际都是通过停机维护来处理的,可能很多开发都经历过,发布停服公告,然后在指定时间内把数据全部追平或者二次搬运,再重新提供服务。但是总有些业务场景是不能停机维护的,处理灰度数据的基本策略如下:

828a3ddb4c03924512205a59f69ec359.png

该模式中,除了正常的灰度流程之外,需要在灰度数据库和正常数据中间提供一个数据调配服务,用来解决如下问题:灰度数据库缺失数据,需要临时从正常库拉取,灰度版本失败,新数据需要重新整合写入原本正常库;灰度版本成功,旧版数据迁移等;最终保证数据的平稳升级。

最后

无论是哪家公司,都很重视基础,大厂更加重视技术的深度和广度,面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。

针对以上面试技术点,我在这里也做一些资料分享,希望能更好的帮助到大家。

戳这里免费领取以下资料

150001a528f86f16b83ffe4476a5adf8.png

878bfec40cc8a7fdae4380374dca3e72.png

b5c927eb5d91d4729166aeedc4a7c10c.png

mg-skXRVVbs-1620138624088)]

[外链图片转存中…(img-VvafHs3J-1620138624089)]

发表评论

表情:
评论列表 (有 0 条评论,543人围观)

还没有评论,来说两句吧...

相关阅读

    相关 Google 分享

    本文公众号来源:程序猿石头 作者:码农唐磊 本文已收录至我的GitHub 去年换工作的时候, 面试了一下 Google (这里说的是 Google 中国), 来了个