工作纪实46-关于微服务的上线发布姿势

蓝绿部署

在部署时,不需要将旧版本的服务停掉,而是将新版本与旧版本同时运行,新版本测试无误之后再将旧版本停掉。这样可以避免再升级的过程中如果失败服务不可用的问题,因为同时部署了两个版本的程序,使得硬件资源是普通部署的两倍。

滚动发布


滚动发布可以解决蓝绿部署需要硬件资源两倍的问题。再升级的过程中,每次替换一个旧版本的副本,直到所有旧版本被替换完毕。但是这样做的缺点是,由于新旧版本同时运行,有些流量会流入到新版本中,但是新版本并不一定是可用的,很难确定是新版本还是旧版本的问题。在滚动发布的过程中,整个系统都趋于不稳定的状态。

灰度发布

又称金丝雀发布,叫金丝雀的原因是在矿井挖掘中,人们发现金丝雀会对瓦斯浓度很敏感,在挖掘前将金丝雀放入到矿井中,如果金丝雀不叫了,那么表示矿井中瓦斯浓度很高。

在试用灰度发布的过程中会新开一个应用程序,让开发人员对应用测试没问题之后,可用将少量流量接入到新版本中,然后将旧版本与新版本各项数据进行对比,如果执行良好之后则可用加大流量,然后将所有旧版本替换成新版本。

相关推荐
fakerth20 小时前
【OpenHarmony】医疗传感器模块架构
架构·操作系统·openharmony
没有bug.的程序员1 天前
云原生与分布式架构的完美融合:从理论到生产实践
java·分布式·微服务·云原生·架构
AWS官方合作商1 天前
AWS WAF 深度体验:全新控制台,开启云原生WAF与CloudFront无缝联防新纪元
云原生·aws
JanelSirry1 天前
分布式和微服务的区别是什么?
分布式·微服务·架构
tianyuanwo1 天前
虚拟机监控全攻略:从基础到云原生实战
linux·云原生·虚机监控
徐子童1 天前
基于微服务的在线判题系统重点总结
java·微服务·架构
递归尽头是星辰1 天前
Docker容器化核心知识体系:从入门到实践
docker·云原生·devops·容器化·镜像构建
天才奇男子1 天前
用户管理,权限管理
linux·云原生
飞哥的AI笔记1 天前
AI群星闪耀时:从识别到思考的认知升级
架构
迎風吹頭髮1 天前
Linux内核架构浅谈44-Linux slab分配器:通用缓存与专用缓存的创建与使用
linux·spring·架构