AICon 深圳站聚焦 Agent 技术、应用与生态,大咖分享实战干货 了解详情
写点什么

Kubernetes 1.2 新功能解析:使用 Deployment

  • 2020-03-13
  • 本文字数:1699 字

    阅读完需:约 6 分钟

Kubernetes 1.2新功能解析:使用Deployment

Kubernetes 令部署应用、管理应用变得简单直白,令大多数操作简化为单个 API 或单个命令行,包括发布新的应用程序,canary 测试和升级。那么为什么我们还需要部署呢?


自动化 Deployment 和滚动更新程序。相比于 kubectl 滚动更新,Deployment API 更加快速,具有描述性,实现服务端,还有更多的功能(比如,即使是在滚动更新完成之后,你也可以回滚到之前的版本)。


在今天的博客中,我们介绍的内容包括如何使用 Deployment 来:


1、配置/推出一个新的应用程序


2、阶段性更新应用程序,中途没有服务中断


3、如果在你部署/更新应用的时候出现错误,你可以回滚到之前的版本。



让我们来尝试使用一下 Deployment 吧~

准备开始

如果你想要试用下面这个例子,基本上需要满足以下三个要求:


1、一个正在运行的 kubernetes 集群:如果你现在还没有创建过集群的话,查看教程,里面有各种平台上的部署方案,包括你的笔记本,虚拟机,裸机服务器等等。


2、Kubectl,Kubernetes CLI:如果在运行 kubectl cluster-info 之后,看到了一个 URL 回应,那么就准备启动吧。否则的话,就按照指示安装配置 kubectl;如果你有谷歌 GCE 集群的话,也可以按照主机解决方案的指示来安装。


3、这个 demo 的配置文件,可以点击。


如果不想自己动手运行这个例子,那也可以。看这个视频了解每一步的细节。

开始

配置文件包括一个静态页面。首先,我们想要开始为它的静态内容服务。从 Kubernetes repository 的 root 开始,运行:



这个在 8001 端口运行了一个 proxy。你现在可以访问:http://localhost:8001/static/ ,就是 demo 网页版(它现在登录进去显示出来的是一个空白页面)。现在我们想要运行一个应用,并且将它展示到网页上。



这些代码用“update-demo:nautilus”部署了一个应用的副本,你可以点击这里观看。



网页上展示的卡片代表的是:一个 Kubernetes pod,pod 的名称(ID),状态,镜像和标签。

数量变大

现在我们想要更多这个应用的复制件!



更新你的应用程序

更新应用会怎么样呢?



此代码打开了你的默认编辑器,然后你可以在 fly 上面更新配置。找到.spec.template.spec.containers[0].image,然后修改 nautilus 到 kitty,然后你会看到:



你现在要做的是将这个应用的镜像从“update-demo:nautilus“更新到”update-demo:kitty“。


过一会儿,你就会发现更新似乎被绊住了。发生了什么呢?

调试 rollout

如果你看的再仔细一点,你会发现那些带有“Kitty”标记的镜像仍处于待定状态。一旦运行失败,Deployment 会自动停止 roll。让我们来看一看新的 pod 上发生了什么:



看一下这个 pod 的 events,你会注意到 Kubernetes 由于找不到“kitty”而无法 pull 镜像:


回滚

好的,现在我们想要撤销做出的修改,然后花时间理清楚我们应该使用哪个镜像标签。



所有东西都恢复到正常,耶!


为了学习更多的关于回滚的知识,访问。

更新你的应用程序(讲真)

之后,我们终于找出正确的镜像标签是“kitten”,而不是“Kitty”。现在将.spec.template.spec.containers[0].的镜像标签从“nautilus”改到“kitten”。



可以看到有 4 只小猫,这也就意味着我们已经成功地更新了应用!如果想要了解这背后的镜像,来看这个的 Deployment 吧:



从 events 章节可以看到配置正在管理另一个叫做 Replica Set 的资源,每一个都管理不同 pod 模版的副本的数字。

结论

现在,你已经了解了 Deployment 对象的基本用法:


1、部署有 Deployment 的应用,使用 kubectl 来运行


2、通过更新 Deployment 来更新应用,用 kubectl 编辑


3、回滚到之前部署的应用,用 Kubectl rollout 撤销


但是还有很多 Deployment 里的东西,在这里篇幅有限,无法详述。为了探究更多,点击这里了解更多:http://kubernetes.io/docs/user-guide/deployments/


注意:在 Kubernetes1.2 中,Deployment(测试版)功能完善,是默认启用的版本。你们之中试用过 Kubernetes1.1 中的 Deployment 的人,在 Kubernetes1.2 上尝试 Deployment 之前请删除所有的 Deployment1.1 资源(包括他们管理的 RC 和 pods)。这个步骤很有必要,因为我们对 API 作了一些反向不兼容的修改。


本文转载自才云 Caicloud 公众号。


原文链接:https://mp.weixin.qq.com/s/Ih_YKgvanMS1zcx9RWkIgQ


2020-03-13 17:261043

评论

发布
暂无评论
发现更多内容

【spring-kafka】@KafkaListener详解与使用

石臻臻的杂货铺

kafka 9月月更

企业在SaaS时代如何玩转帮助中心?

Baklib

【云原生 | 从零开始学Docker】五、容器数据卷实战

泡泡

Docker 云计算 容器 云原生 9月月更

MySQL 中的锁机制

月明风清

谁能说清楚数据资产管理与数据治理是什么关系?

雨果

数据治理

跟着卷卷龙一起学Camera--Binder

卷卷龙

ISP 9月月更

数据仓库分层架构

阿泽🧸

数据仓库 9月月更

【云原生 | 从零开始学Docker】四、Docker镜像深度解析

泡泡

Docker 云计算 容器 云原生 9月月更

元宇宙与泛娱乐的邂逅:次世代第一CP养成记

脑极体

大数据ELK(二):Elasticsearch简单介绍

Lansonli

elasticsearch 9月月更

数据、管理、分析和运营:大数据专家面临的四大挑战!

雨果

大数据

经验分享|企业搭建帮助中心步骤

Baklib

前端经典面试题(有答案)

loveX001

JavaScript 前端

前端常见react面试题合集

beifeng1996

前端 React

2022前端经典vue面试题(持续更新中)

bb_xiaxia1998

Vue 前端

2022前端二面必会vue面试题汇总

bb_xiaxia1998

Vue 前端

企业做好知识管理的方法:文档管理

Baklib

SaaS 产品该如何定价?

产品海豚湾

产品经理 SaaS 产品规划 9月月更 商业产品

你知道数据资产管理的目标是什么?

雨果

数据中台 数据资产管理

《数字经济全景白皮书》新市民金融创新篇 重磅发布!

易观分析

金融 新市民服务

leetcode 637. Average of Levels in Binary Tree 二叉树的层平均值(简单)

okokabcd

LeetCode 数据结构与算法

2022-09-15:Range模块是跟踪数字范围的模块。 设计一个数据结构来跟踪表示为 半开区间 的范围并查询它们。 半开区间 [left, right) 表示所有 left <= x < righ

福大大架构师每日一题

算法 rust 福大大

易观分析:制造行业数字孪生AMC分析 ——数字孪生智能制造步入市场启动期,闭环验证能力待优化

易观分析

数字孪生 市场分析

什么是访问控制列表ACL?

wljslmz

acl 访问控制列表 9月月更

[极致用户体验] 让你的网页,适配微信大字号模式!体验超好,快来收藏

HullQin

CSS JavaScript html 前端 9月月更

20道高频react面试题(附答案)

beifeng1996

前端 React

MFC模拟消息发送,自定义以及系统消息

中国好公民st

c++ 消息分发 9月月更

Java进阶(二十一)java 空字符串与null区别

No Silver Bullet

Java null 9月月更 空字符串

C++学习---STL中nullptr_t的实现原理

桑榆

c++ 源码阅读 9月月更

谁来说说数据质量评估的标准是什么?

雨果

数据质量

Kubernetes 1.2新功能解析:使用Deployment_语言 & 开发_才云科技_InfoQ精选文章