Kubernetes应用跨可用区实战

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
简介: 本文介绍了如何在阿里云Kubernetes集群部署跨多个可用区的应用。

kubernetes_multi_zone

本文介绍了如何在阿里云Kubernetes集群部署跨多个可用区的应用。

应用跨多个可用区

为了保证业务应用的高可用,有些客户会要求关键应用部署到多个机房,一个机房一旦出问题,其他机房正常工作,从而让应用保持不间断连续运行。

类似这样的能力在云上如何实现呢?阿里云有Region(地域)和Zone(可用区)的概念。简单点理解,Region对应城市,例如“华东1”为杭州,“华北2”为北京等。Zone为Region下按照电力和网络设备等相互独立的的可用区,不同的可用区可能在一个物理机房中。同一个地域内的不同可用区之间内网是连通的,网络延迟很小。

阿里云Kubernetes集群已经支持跨多个可用区部署,下面我们就看看如何在Kubernetes部署一个跨多个可用区的应用。

在集群中添加其他可用区节点

在创建集群的时候需要选择ECS所在的可用区。集群创建好后,需要首先在集群中添加其他可用区的节点。

topology_001

我现在的这个集群在华东1可用区B,我在可用区F创建了一个新的ECS。点击集群“更多”/“添加已有节点”。

add_node

选择“自动添加”,勾选准备添加的ECS,点击下一步继续设置。

select_node

等待集群添加节点成功后,可以在集群节点列表中看到新添加的ECS。

list_node

ECS的可用区标签

在Kubernetes集群中通过标签来区分ECS所在的Region和Zone,点击任意节点的“详情”菜单,可以看到如下的标签failure-domain.beta.kubernetes.io/zone: cn-hangzhou-f

node_labels

这是可用区F的标签,对于集群中的其他节点,对应的标签为failure-domain.beta.kubernetes.io/zone: cn-hangzhou-b

部署Nginx跨多个可用区

在部署应用的时候,可以利用nodeAffinity来指定该应用所有实例“平均”分配在可用区B和可用区F。

      affinity:
        nodeAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            nodeSelectorTerms:
            - matchExpressions:
              - key: failure-domain.beta.kubernetes.io/zone
                operator: In
                values:
                - cn-hangzhou-b
                - cn-hangzhou-f

完整的部署描述文件如下:

apiVersion: extensions/v1beta1
kind: Deployment
metadata:
  name: nginx-multi-zone
spec:
  replicas: 6
  selector:
    matchLabels:
      app: nginx-multi-zone
  template:
    metadata:
      labels:
        app: nginx-multi-zone
    spec:
      affinity:
        nodeAffinity:
          requiredDuringSchedulingIgnoredDuringExecution:
            nodeSelectorTerms:
            - matchExpressions:
              - key: failure-domain.beta.kubernetes.io/zone
                operator: In
                values:
                - cn-hangzhou-b
                - cn-hangzhou-f
      containers:
      - name: nginx-multi-zone
        image: nginx:latest
        ports:
        - containerPort: 80

部署应用后,可以看到nginx的6个实例,分布在2个可用区中。

multi-zone $ kubectl get po -l app=nginx-multi-zone -o wide
NAME                                READY     STATUS    ...   NODE
nginx-multi-zone-65f7b68b69-7bsm9   1/1       Running   ...   cn-hangzhou.i-...dog
nginx-multi-zone-65f7b68b69-94j59   1/1       Running   ...   cn-hangzhou.i-...upb  # Zone F
nginx-multi-zone-65f7b68b69-9t5w5   1/1       Running   ...   cn-hangzhou.i-...upb  # Zone F
nginx-multi-zone-65f7b68b69-m9n94   1/1       Running   ...   cn-hangzhou.i-...doe
nginx-multi-zone-65f7b68b69-swxzd   1/1       Running   ...   cn-hangzhou.i-...dof
nginx-multi-zone-65f7b68b69-t99f5   1/1       Running   ...   cn-hangzhou.i-...upb  # Zone F

由于这个集群中只有一个节点在可用区F,可以看到3个nginx实例运行在upb节点上,其余3个实例运行在可用区B的3个不同的ECS上。

福利:如何创建Master节点跨多可用区的集群

上面谈到了把可用区F的ECS加入到可用区B的集群中。这个集群的所有Master节点都在可用区B中。那么能否创建集群让其Master节点也跨多个可用区呢?

答案是创建多可用区Kubernetes集群,点击创建Kubernetes集群右侧的下拉菜单,可以看到如下界面:

create_mz_cluster_crop

在创建多可用区集群之前,首先在3个可用区创建好VPC交换机,然后在创建集群界面选择3个交换机机,再指定Master和Worker节点配置即可。

后续操作很直观,这里就不贴图了,读者可以自行尝试。

小结

利用可用区的概念可以做到应用的跨可用区高可用,这在对于可用性要求非常高的场景中非常实用。阿里云容器服务提供了生产级稳定的Kubernetes服务,更多内容读者可以访问https://www.aliyun.com/product/kubernetes

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
20天前
|
Prometheus Kubernetes 监控
k8s学习--kubernetes服务自动伸缩之水平伸缩(pod副本伸缩)HPA详细解释与案例应用
k8s学习--kubernetes服务自动伸缩之水平伸缩(pod副本伸缩)HPA详细解释与案例应用
k8s学习--kubernetes服务自动伸缩之水平伸缩(pod副本伸缩)HPA详细解释与案例应用
|
16天前
|
应用服务中间件 调度 nginx
Kubernetes的Pod调度:让你的应用像乘坐头等舱!
Kubernetes的Pod调度:让你的应用像乘坐头等舱!
|
18天前
|
存储 Kubernetes 负载均衡
基于Ubuntu-22.04安装K8s-v1.28.2实验(四)使用域名访问网站应用
基于Ubuntu-22.04安装K8s-v1.28.2实验(四)使用域名访问网站应用
18 1
|
20天前
|
Kubernetes 负载均衡 应用服务中间件
k8s学习--ingress详细解释与应用(nginx ingress controller))
k8s学习--ingress详细解释与应用(nginx ingress controller))
|
20天前
|
缓存 Kubernetes 负载均衡
k8s学习--sessionAffinity会话保持(又称会话粘滞)详细解释与应用
k8s学习--sessionAffinity会话保持(又称会话粘滞)详细解释与应用
|
27天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
|
1月前
|
Kubernetes 监控 Cloud Native
云原生入门:从传统应用到容器化部署的旅程
【9月更文挑战第19天】在数字化浪潮中,企业正迅速将目光投向云原生技术,以实现更快的应用开发和更灵活的资源管理。本文将通过一个简单示例引导读者理解如何将传统应用转变为云原生应用,并部署至云端。我们将探索容器化技术的基础,以及它如何帮助企业解锁现代软件交付的速度和效率。准备好让你的应用乘上云原生的快车了吗?让我们开始这段令人兴奋的旅程吧!
|
1月前
|
存储 Kubernetes 负载均衡
CentOS 7.9二进制部署K8S 1.28.3+集群实战
本文详细介绍了在CentOS 7.9上通过二进制方式部署Kubernetes 1.28.3+集群的全过程,包括环境准备、组件安装、证书生成、高可用配置以及网络插件部署等关键步骤。
261 3
CentOS 7.9二进制部署K8S 1.28.3+集群实战
|
1月前
|
Kubernetes 负载均衡 前端开发
二进制部署Kubernetes 1.23.15版本高可用集群实战
使用二进制文件部署Kubernetes 1.23.15版本高可用集群的详细教程,涵盖了从环境准备到网络插件部署的完整流程。
76 2
二进制部署Kubernetes 1.23.15版本高可用集群实战
|
1月前
|
Kubernetes Cloud Native Linux
云原生入门:Kubernetes的简易部署与应用
【8月更文挑战第49天】在云原生的世界里,Kubernetes(K8s)是一颗璀璨的星。本文将带你走进K8s的世界,从安装到简单应用,轻松驾驭这个强大的容器编排工具。让我们一起探索云原生的奥秘,解锁新技能!

相关产品

  • 容器服务Kubernetes版