Argo 推出的无压力部署选项
admin
2024-02-06 02:51:57
0

什么是渐进式交付?
用户希望他们的应用程序始终可用。IT 专业人员希望尽可能快速、顺利地部署他们的软件。

渐进式交付是软件交付策略的一个术语,旨在逐步发布新功能。

我们正在谈论由 Kubernetes 容器化和管理的生产环境。无论您使用什么策略来部署您的应用程序,您将始终处理这两个要素:

1)集群
集群是在网络中链接在一起的一组计算机。每台计算机都是一个节点。集群的目的是利用计算速度解决难题并提高数据完整性。Kubernetes 集群是一组运行容器化应用程序的节点。容器打包应用程序及其依赖项。

2)负载均衡器
该组件负责有效地将传入的网络流量分配给一组服务器。

大爆炸
这是部署新版本软件的最便宜和最原始的方法之一。这不完全是一种策略,但看起来像是一种自然的方式。在部署期间,旧版本被销毁并安装新版本。

此模型的一个明显问题是关闭稳定版本和启动新版本之间的停机时间。总是想着最好的情况,这个停机时间可以说是微不足道的,也许就几秒钟吧。但是,在最坏的情况下,它可能会持续几天。当然,除了所有这些产生的压力之外,没有人愿意冒险让他们的生产环境长期停止运行。

如果应用程序不是关键的、不是业务的一部分或者根本不需要高可用性,那么这种基本的部署形式可能是一个有效的替代方案。

蓝绿色
在blue/green 策略中,使用了两个相同的环境,一个称为 blue,另一个称为 green,分别代表 staging 和 production。其中一个环境存储稳定版本,另一个环境存储新部署的版本。如果验收测试成功,则负载均衡器流量将被定向到运行最新版本的环境。

在此部署期间,没有停机时间。该过程简单且快速。

当以前的版本正在运行时,我们可以通过再次将负载均衡器指向它来进行回滚。

蓝/绿的一些明显问题是需要双后端,以及当前和以前的后端同时运行时速度变慢的可能性。另一个需要考虑的因素是财务。

滚动更新
在滚动更新策略中,更新是增量的:一个 pod 终止,而另一个 pod 使用新的软件版本启动。在部署过程中,最多可以不可用的Pod数量只有一个,最多可以创建的Pod数量也只有一个。

滚动更新是默认的 Kubernetes 策略,用于大多数云服务。

金丝雀
在金丝雀模型中,部署是增量的,就像滚动更新一样。

金丝雀模型的思想是先将更改部署到一小组服务器,对其进行测试,然后再将其部署到其余服务器。这种部署方式作为一种预警指标,对宕机的影响较小,即如果第一次部署失败,其余服务器不会受到影响。此升级是分阶段进行的,例如,先升级 10%,然后升级 25%,直到达到 100% 升级。

阿尔戈光盘
用工具本身的文档来解释一下:“Argo CD 是一种用于 Kubernetes 的声明式 GitOps 持续交付工具。”

但什么是 GitOps?简而言之,GitOps 是一组实践,使开发人员能够执行通常属于 IT 运营团队职权范围的任务。

Argo CD 是一个大大简化部署过程的工具,易于安装,直观,具有许多功能,并且是开源的。

为了丰富这种体验,让我们从安装 Argo CD 开始做一个快速演示。假设您已经在桌面上安装了 Kubectl 和 Minikube。

一个重要的要求是您启用了入口控制器。要在 Minikube 中启用此功能,请使用以下命令:

$ minikube addons enable ingress
如果您还从 Github 下载以下项目,一切都会更简单:https ://github.com/marceloweb/exp-cd.git 。

$ git clone https://github.com/marceloweb/exp-cd.git
$ cd exp-cd/
在这个项目中,我对 Istio 进行了一些配置,这是一个服务网格,为我们提供了一些有趣的工具,尤其是在使用金丝雀的策略中。

$ kubectl apply -f istio/
下一步是安装 Argo CD。

$ kubectl create namespace argocd
$ kubectl apply -n argocd -f https://raw.githubusercontent.com/argoproj/argo-cd/stable/manifests/install.yaml
$ kubectl patch svc argocd-server -n argocd -p '{"spec": {"type": "LoadBalancer"}}'
要在浏览器中访问 Argo CD,请确保您已初始化所有 pod。然后,使用以下命令,从 Argo CD 获取管理员密码和端口转发。

$ kubectl port-forward svc/argocd-server -n argocd 8080:443
$ kubectl -n argocd get secret argocd-initial-admin-secret -o jsonpath="{.data.password}" | base64 -d; echo
建议在另一个终端窗口中进行端口转发。

完成这些步骤后,您可以在浏览器中访问 https://localhost:8080 并输入用户“admin”和新生成的密码。

登录后,您必须单击“新建应用程序”以注册您要使用 Argo CD 部署的第一个软件。

对于此示例,我在字段中填写了以下值:

应用程序名称: realtimeapp

项目名称: 默认

同步策略: 手动

存储库网址: https ://github.com/marceloweb/exp-cd.git

修订:  HEAD

路径:  argo

集群 URL: https://kubernetes.default.svc

命名空间: 默认

其他字段我保持不变。填写完字段后,我单击了“创建”按钮。

一切顺利的话,Argo CD 主界面会出现新注册的 app,如下图:

Argo 推出
安装 Argo CD 后,我们已经有了一个可以简化部署过程的工具。现在添加 Argo Rollouts 允许我们使用我们在几行之前介绍的策略。

Argo Rollouts 是出色的开源 Argo 项目中的另一个工具。Argo Rollouts 是一个 Kubernetes 控制器,可促进渐进式交付策略的实施。它还可以与入口控制器和服务网格集成。

让我们首先使用以下命令安装该工具:

$ kubectl create namespace argo-rollouts
$ kubectl apply -n argo-rollouts -f https://github.com/argoproj/argo-rollouts/releases/latest/download/install.yaml
安装完成后,我们可以在Argo CD上进行测试。为此,我们将单击我们刚刚注册的应用程序,然后单击“同步”按钮,然后单击“同步”。

将进行第一次部署。

接下来,我们将更改项目中的 canary.yml 文件,在 argo 目录中,在与要应用的图像版本对应的行中。在这种情况下,我从 v1.0-1 更改为 v1.0-2

再次点击“Synchronize”和“Synchronize”按钮后,Argo CD 开始按照已经定义好的规则执行 canary.yml 文件中配置的所有步骤。我们的应用程序在任何时候都不会停机。

我们可以通过 Dashboard 跟踪部署,注意只要在 canary.yml 文件中定义了暂停,在 Dashboard 中,值“Suspended”就会显示在 App Health 标签下。我们还可以使用以下命令通过终端跟踪部署:

$ kubectl argo rollouts get rollout realtimeapp
它将显示在下图中:

成功完成后,App Health 标签显示 Healthy 值,如下图所示:

也可以通过终端查询来验证部署是否成功:

相关内容

热门资讯

消息称百度旗下昆仑芯瞄准500... 6 月 29 日消息,据《The Information》昨日援引知情人士消息,百度旗下 AI 芯片...
打造夏日消费新场景 第35届北... 北京商报讯(记者 翟枫瑞)6月29日消息,第35届北京国际燕京啤酒文化节新闻发布会在京举行。本届啤酒...
社保基金持仓数据出炉,一季度增... 最近各大上市公司一季度财报都公开了,咱们国家社保基金的持仓数据也全部曝光。目前社保拿着比亚迪价值44...
36氪首发 | 海思、中兴团队... 作者 | 乔钰杰 编辑 | 袁斯来 硬氪获悉,广州宸思通讯科技有限公司(以下简称“宸思科技”)近日完...
两天蒸发47亿市值!一纸税务通... 一纸税务通知书,能让一家百亿龙头两天蒸发47亿市值。 6月22日,北大荒(600598.SH)公告称...
SK海力士将投资1100万亿韩... SK集团会长崔泰源6月29日在韩国“三大重大计划”发布会上宣布,公司将投资1100万亿韩元扩大半导体...
两只A股,终止上市! 两家A股公司,即将摘牌。 6月29日,退市沪科(600608.SH)公告称,上海证券交易所将在202...
原创 M... 一家成立近十年的自动驾驶公司,在IPO时吸引了14家基石投资者认购近一半的发行股份,其中不乏奔驰、比...
基金忠言|国寿安保滤镜碎,三年... 图片来源:视觉中国 蓝鲸新闻6月29日讯(记者 祁和忠)保险系基金公司国寿安保总经理换人了。 6月2...
三星电机计划加码玻璃基板!相关... 6月29日,玻璃基板概念股午后有所回升, 华工科技(000988.SZ)逼近涨停, 彩虹股份(600...
拉萨海关持续壮大外贸经营主体 ...   新华网拉萨6月28日电(记者蒋梦辰)近日,记者从拉萨海关获悉,今年前5个月,西藏有进出口实绩的外...
机构:二季报临近,医药生物板块... 6月29日,华源证券发布了一篇医药生物行业的研究报告,报告指出,业绩期临近,产业链景气度有望再次迎来...
每日收评科创50放量涨超4.5... 财联社6月29日讯,三大指数全线收红,创业板指探底回升,科创50指数大涨4.61%。沪深两市成交额3...
6月多地土拍结构性升温:深圳单... 进入2026年6月,不少城市核心区地块集中诞生高溢价宗地,热度突出的城市包含深圳、杭州、长沙。 其中...
业绩炸裂!盛达资源半年预盈3.... 6月29日,贵金属矿山龙头盛达资源(000603.SZ)发布 2026 年半年度业绩预告,上半年业绩...
A股午后拉升三大股指收涨:半导... A股三大股指6月29日开盘涨跌互现。早盘沪强深弱,创指一度跌超2%。半导体午后拉升,带动两市上涨,沪...
原创 空... 前言 大家好,我是老金。 这几天,两幅极度割裂的画面放在一起,把我看笑了。 一边是在持续的热浪下,欧...
澳大利亚审慎监管局拟放宽银行风... 澳大利亚审慎监管局(APRA)6月29日就修改 银行信用风险资本设定公开征求意见,旨在加大信贷投放以...
全民炒股,急踩刹车!韩国股市突... 屈红燕/证券时报网 全民狂欢、交易高度拥挤、杠杆资金猛增、新入市投资者表现激进、大型IPO吸金等现象...