K8S之实现业务的蓝绿部署

如何实现蓝绿部署

  • 什么是蓝绿部署?
  • 蓝绿部署的优势和缺点
    • 优点
    • 缺点
  • 通过k8s实现线上业务的蓝绿部署

什么是蓝绿部署?

部署两套系统:一套是正在提供服务系统,标记为 “绿色” ;另一套是准备发布的系统,标记为 “蓝色”。
两套系统都是功能完善的、正在运行的系统,只是系统版本和对外服务情况不同。
要用开发的新版本替换线上的旧版本,除了已上线运行的系统之外,再搭建一个使用新版本代码的全新系统。这时候,一共有两套系统在运行,正在对外提供服务的老系统是绿色系统,新部署的系统是蓝色系统。
在这里插入图片描述
蓝色系统 用来做发布前测试,测试过程中发现任何问题,可以直接在蓝色系统上修改,不干扰用户正在使用的系统。(ps. 两套系统没有耦合的时候才能百分百保证不干扰)

蓝色系统经过反复的测试、修改、验证,确定达到上线标准之后,直接将用户切换到蓝色系统。
在这里插入图片描述
切换后的一段时间内,依旧是蓝绿两套系统并存,但是用户访问的已经是蓝色系统。这段时间内观察蓝色系统(新系统)工作状态,如果出现问题,直接切换回绿色系统。

当确信对外提供服务的蓝色系统工作正常,不对外提供服务的绿色系统已经不再需要的时候,蓝色系统正式成为对外提供服务系统,成为新的绿色系统。 原先的绿色系统可以销毁,将资源释放出来,用于部署下一个蓝色系统。

蓝绿部署的优势和缺点

优点

  • 更新过程无需停机,风险较少
  • 回滚方便,只需要更改路由或者切换DNS服务器,效率较高

缺点

  • 成本较高,需要部署两套环境。
  • 在非隔离的机器(Docker、VM)上操作时,可能会导致蓝绿环境被摧毁风险
  • 负载均衡器/反向代理/路由/DNS处理不当,将导致流量没有切换过来情况出现

通过k8s实现线上业务的蓝绿部署

方式:创建deployment,然后更新应用程序的service以指向对应deployment部署的应用

实践说明:将项目老版本(v1)代码和新版本(v2)代码做成不同的镜像。
实践步骤:

1、创建绿色部署环境(基于v1版本做的镜像)

通过deployment来创建运行pod

vim  green.yaml

编写Deployment资源文件

apiVersion: apps/v1
kind: Deployment
metadata:name: myapp-v1namespace: blue-green
spec:replicas: 3selector:matchLabels:app: myappversion: v1template:metadata:labels:app: myappversion: v1spec:containers:- name: myappimage: janakiramm/myapp:v1imagePullPolicy: IfNotPresentports:- containerPort: 80

使用kubectl命令创建部署

1.1、先创建命名空间

kubectl create ns blue-green

1.2、创建资源服务

kubectl apply -f green.yaml

查看pod运行情况

kubectl get pods -n blue-green

在这里插入图片描述

kubectl get pods -n blue-green --show-labels

在这里插入图片描述

1.3、创建前端Service

编写Service资源文件

vim service-blue-green.yaml 
apiVersion: v1
kind: Service
metadata:name: myapp-blue-greennamespace: blue-greenlabels:app: myapp
spec:type: NodePortports:- port: 80nodePort: 30062name: httpselector:app: myappversion: v1

更新服务

kubectl apply -f service-blue-green.yaml

查看Service

kubectl get svc -n blue-green

在这里插入图片描述

在浏览器访问 “ http://k8s-master1节点的IP:30062 ” 显示如下:
在这里插入图片描述

2、创建蓝色部署环境(基于v2版本做的镜像,即新上线的环境,要替代绿色环境)

通过deployment来创建运行pod

vim  blue.yaml

编写Deployment资源文件

apiVersion: apps/v1
kind: Deployment
metadata:name: myapp-v2namespace: blue-green
spec:replicas: 3selector:matchLabels:app: myappversion: v2template:metadata:labels:app: myappversion: v2spec:containers:- name: myappimage: janakiramm/myapp:v2imagePullPolicy: IfNotPresentports:- containerPort: 80

使用kubectl命令创建部署

kubectl apply -f blue.yaml

验证部署是否成功

kubectl get pods -n blue-green

在这里插入图片描述

修改 service-blue-green.yaml 配置文件(即修改标签),让其匹配到蓝程序(即升级之后的版本)

vim service-blue-green.yaml
apiVersion: v1
kind: Service
metadata:name: myapp-blue-greennamespace: blue-greenlabels:app: myapp
spec:type: NodePortports:- port: 80nodePort: 30062name: httpselector:app: myappversion: v2 # 修改此处,由 v1 改为 v2

更新服务

kubectl apply -f service-blue-green.yaml

查看Service

kubectl get svc -n blue-green

在这里插入图片描述

在浏览器访问 “ http://k8s-master1节点的IP:30062 ” 显示如下:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/519935.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Spring事务注解@Transactional的流程和源码分析

Spring事务简介 Spring事务有两种方式: 编程式事务:编程式事务通常使用编程式事务管理API实现,比如Spring提供的PlatformTransactionManager接口,使用它操控事务。声明式事务:注解式事务使用AOP(面向切面…

亚信安慧AntDB:企业数据管理的明日之星

在信息科技飞速发展的时代,亚信科技AntDB团队提出了一项颠覆性的“超融合”理念,旨在满足企业日益增长的复杂混合负载和多样化数据类型的业务需求。这一创新性框架的核心思想在于融合多引擎和多能力,充分发挥分布式数据库引擎的架构优势&…

《操作系统真相还原》读书笔记一:环境搭建 32位centos6.3+bochs

下载32位的centos6.3centos6.3 https://archive.kernel.org/centos-vault/6.3/isos/i386/ 在virtualbox中安装centos6.3 1、系统运维中常用的Linux操作系统是红帽Linux或者CentOS。 从官方网站下载CentOS 6.3镜像光盘。 2、运行虚拟机,在选择界面选择"Inst…

如何将中科方德桌面操作系统加入Windows域

往期文章:自定义SSH客户端连接时的显示信息 | 统信UOS | 麒麟KYLINOS Hello,大家好啊,今天我非常高兴地给大家带来一篇关于如何将中科方德桌面操作系统加入Windows域的教程文章。对于使用中科方德桌面操作系统的用户来说,将其加入…

【设计模式 05】原型模式

有的时候,我们创建对象,需要耗费大量时间在一些资源型操作上,这个时候,我们就可以先创建出一个模板,然后每次创建的时候直接从模板复制即可,不用反复进行耗时的资源型操作。 python代码: impo…

一命通关前缀和

前缀和 简介 先来简单看一个场景。现在有一个公交车,第一站上了4个人,第二站上了7个人,第三站上了1个人,第四站上了5个人,问一共上了多少人? 答案很显而易见,只需要遍历这个数组,把…

使用PHP实现动态代理IP的功能

目录 前言 一、 什么是代理IP 二、动态代理IP的原理 三、使用ProxyCrawl API获取代理IP 安装和配置 发送请求获取代理IP 实现动态代理IP的功能 总结 前言 动态代理IP是一种通过不断切换不同的代理IP来隐藏真实IP地址的技术。在使用网络爬虫、进行数据采集、访问被封IP…

基于 Win Server 2008 复现 IPC$ 漏洞

写在前面 本篇博客演示了使用 winXP(配合部分 win10 的命令)对 win server 2008 的 IPC$ 漏洞进行内网渗透,原本的实验是要求使用 win server 2003,使用 win server 2003 可以规避掉很多下面存在的问题,建议大家使用 …

k8s 网络概念与策略控制

一、Kubernetes 基本网络模型 Kubernetes 的容器网络模型可以把它归结为约法三章和四大目标。 1、约法三章 约法三章确保了Kubernetes容器网络模型的基本特性: ① 任意两个 pod 之间可以直接通信:在Kubernetes中,每个 Pod 都被分配了一个…

ResponseStatusException

目录 概述: 综合实例: 继承 ResponseStatusException-自定义异常类 继承 ResponseStatusException-自定义响应头信息 继承 ResponseStatusException-定制更多异常处理逻辑 继承 ResponseStatusException-根据异常发生的上下文动态改变 HTTP 状态码…

网络协议栈--应用层--HTTP协议

目录 本节重点理解应用层的作用, 初识HTTP协议 一、应用层二、HTTP协议2.1 认识URL2.2 urlencode和urldecode2.3 HTTP协议格式2.4 HTTP的方法2.4 HTTP的状态码2.5 HTTP常见的Header属性 三、最简单的HTTP服务器3.1 HttpServer.hpp3.2 HttpServer.cc3.3 HttpClient.cc3.4 log.hp…

Allure小白下载安装

1、下载官网地址:https://github.com/allure-framework/allure2/releases 2、下载安装包后需要解压到一个非中文名称路径下 3、配置环境变量 D:\Allure\allure-2.27.0\bin 我的电脑右键选择属性,高级系统设置,环境变量 4、CMD查看安装all…