字节跳动Java三面凉凉,掌握这些知识点再也不怕面试通不过!
作者:互联网
# 一、服务发布简介
分布式系统架构下,服务发布是一件很麻烦的事情,特别是在构建自动发布流程和灰度测试的策略两个核心方面。通常情况下如果不涉及数据层面的灰度流程,服务可以灰度上线,或者滚动上线,这两种方式很常用;如果涉及到数据灰度,则可能需要中间服务做不同版本数据之间追平,或者停机维护一次性处理好数据和上线问题,不过后面这种方式风险较大。
# 二、蓝绿部署
![](http://www.icode9.com/i/li/?n=2&i=images/20210630/1625066171230776.jpg)
新版本上线的时候,并不停掉老版本,新旧两个版本同时运行,通常还会在负载均衡的策略上倾向于旧版本服务处理请求,这样新版本就有一个执行的观察期过渡期,等到新版本平稳运行一段时间后,再把请求都发到新版服务上,旧版本服务完成下线。这种方式在分布式架构下很少使用,对服务器要求过高。
# 三、滚动发布
![](http://www.icode9.com/i/li/?n=2&i=images/20210630/1625066172134986.jpg)
滚动发布可以避免蓝绿部署的服务器资源占用问,首先发布一台新版本服务,然后停掉一台老版本服务,新版服务经过观察之后,再逐步替换掉所有老版本的服务,这样服务的环境变动比较频繁,相对不稳定。
# 四、灰度发布
上述两种方式在普通业务场景下都还算好操作,分布式系统下的灰度发布复杂程序相对高很多,基础流程如下:
![](http://www.icode9.com/i/li/?n=2&i=images/20210630/1625066172500538.jpg)
新版本上线,可能涉及分布式下多个灰度服务,因此在服务在整个链路上分发时,都要判断下个请求是路由到正常服务还是灰度服务,还要对灰度服务做请求的权重控制,不能让灰度服务处理大量的请求。
**实际策略**:在实际的分布式系统灰度发布流程,通常会采用如下一个策略:
* 配置一个灰度是否开启的标识;
* 配置一批灰度账户,通常内部人员;
* 配置灰度服务版本标识;
* 请求在链路执行时,判断灰度是否开启;
* 判断当前用户身份是否是灰度测试账号;
* 获取当前可以请求的服务列表;
* 根据灰度服务版本选择请求的具体服务;
这个流程非常的复杂,需要很多自定义的策略,还要熟悉分布式框架的底层API原理,要二次重写来适配灰度策略,设计重写原生API还容易触发一些惊喜问题。
# 五、数据库灰度
如果说最难处理的灰度模式是什么,就是数据库的版本灰度问题,通常业务对数据库改造升级,实际都是通过停机维护来处理的,可能很多开发都经历过,发布停服公告,然后在指定时间内把数据全部追平或者二次搬运,再重新提供服务。但是总有些业务场景是不能停机维护的,处理灰度数据的基本策略如下:
![](http://www.icode9.com/i/li/?n=2&i=images/20210630/1625066172798373.jpg)
该模式中,除了正常的灰度流程之外,需要在灰度数据库和正常数据中间提供一个数据调配服务,用来解决如下问题:灰度数据库缺失数据,需要临时从正常库拉取,灰度版本失败,新数据需要重新整合写入原本正常库;灰度版本成功,旧版数据迁移等;最终保证数据的平稳升级。
# 总结:心得体会
既然选择这个行业,选择了做一个程序员,也就明白只有不断学习,积累实战经验才有资格往上走,拿高薪,为自己,为父母,为以后的家能有一定的经济保障。
学习时间都是自己挤出来的,短时间或许很难看到效果,一旦坚持下来了,必然会有所改变。不如好好想想自己为什么想进入这个行业,给自己内心一个答案。
面试大厂,最基本的就是夯实的基础,不然面试官随便一问你就凉了;其次会问一些技术原理,还会看你对知识掌握的广度,最重要的还是你的思路,这是面试官比较看重的。
最后,上面这些大厂面试真题都是非常好的学习资料,通过这些面试真题能够看看自己对技术知识掌握的大概情况,从而能够给自己定一个学习方向。包括上面分享到的学习指南,你都可以从学习指南里理顺学习路线,避免低效学习。
**[领取上述资料,只需点击这里即可免费下载](https://docs.qq.com/doc/DSmxTbFJ1cmN1R2dB)**
**大厂Java架构核心笔记(适合中高级程序员阅读):**
![](http://www.icode9.com/i/li/?n=2&i=images/20210630/1625066173720137.jpg)
标签:知识点,服务,https,凉凉,灰度,版本,images,Java,com 来源: https://blog.51cto.com/u_15288758/2961770