Kubernetes应用跨可用区实战

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: 本文介绍了如何在阿里云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

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
3月前
|
存储 运维 Kubernetes
批处理及有状态等应用类型在 K8S 上应该如何配置?
批处理及有状态等应用类型在 K8S 上应该如何配置?
|
3月前
|
Kubernetes 应用服务中间件 nginx
百度搜索:蓝易云【使用Kubernetes部署Nginx应用教程】
现在,你已经成功在Kubernetes集群上部署了Nginx应用。通过访问Service的外部IP地址,你可以访问Nginx服务。
44 4
|
4月前
|
Kubernetes 监控 调度
Kubernetes Pod调度:从基础到高级实战技巧
Kubernetes Pod调度:从基础到高级实战技巧
214 0
|
2月前
|
Kubernetes Java 容器
部署 Spring Boot 应用到 K8S 教程
部署 Spring Boot 应用到 K8S 教程
64 0
|
4月前
|
存储 Kubernetes 监控
Kubernetes快速进阶与实战:构建可靠的容器化应用平台
Kubernetes快速进阶与实战:构建可靠的容器化应用平台
108 0
|
3天前
|
Kubernetes 应用服务中间件 nginx
Kubernetes详解(六)——Pod对象部署和应用
在Kubernetes系列中,本文聚焦Pod对象的部署和管理。首先,通过`kubectl run`命令创建Pod,如`kubectl run pod-test --image=nginx:1.12 --port=80 --replicas=1`。接着,使用`kubectl get deployment`或`kubectl get pods`查看Pod信息,添加`-o wide`参数获取详细详情。然后,利用Pod的IP地址进行访问。最后,用`kubectl delete pods [Pod名]`删除Pod,但因Controller控制器,删除后Pod可能自动重建。了解更多细节,请参阅原文链接。
9 5
|
6天前
|
Kubernetes Cloud Native 持续交付
【Docker专栏】Kubernetes与Docker:协同构建云原生应用
【5月更文挑战第7天】本文探讨了Docker和Kubernetes如何协同构建和管理云原生应用。Docker提供容器化技术,Kubernetes则负责容器的部署和管理。两者结合实现快速部署、自动扩展和高可用性。通过编写Dockerfile创建镜像,然后在Kubernetes中定义部署和服务进行应用暴露。实战部分展示了如何部署简单Web应用,包括编写Dockerfile、构建镜像、创建Kubernetes部署配置以及暴露服务。Kubernetes还具备自动扩展、滚动更新和健康检查等高级特性,为云原生应用管理提供全面支持。
【Docker专栏】Kubernetes与Docker:协同构建云原生应用
|
7天前
|
Kubernetes Cloud Native 持续交付
构建高效云原生应用:Kubernetes与微服务架构的融合
【5月更文挑战第6天】 在数字化转型的浪潮中,企业正迅速采纳云原生技术以实现敏捷性、可扩展性和弹性。本文深入探讨了如何利用Kubernetes这一领先的容器编排平台,结合微服务架构,构建和维护高效、可伸缩的云原生应用。通过分析现代软件设计原则和最佳实践,我们提出了一个综合指南,旨在帮助开发者和系统架构师优化云资源配置,提高部署流程的自动化水平,并确保系统的高可用性。
29 1
|
15天前
|
Kubernetes Cloud Native 持续交付
构建高效云原生应用:以Kubernetes为核心
【4月更文挑战第27天】 在当今数字化转型的浪潮中,企业急需构建灵活、可扩展的应用来应对不断变化的市场需求。云原生技术以其独特的优势应运而生,成为推动现代应用开发和部署的重要力量。本文深入探讨了云原生的核心组件之一——Kubernetes,解析其如何通过容器编排优化资源利用,提高应用的弹性和可维护性。同时,文章将展示如何在云平台上实现高效的服务发现、自动扩缩容以及持续集成和持续部署(CI/CD),进一步阐述云原生架构下的最佳实践和面临的挑战。
|
15天前
|
Kubernetes 负载均衡 Docker
【专栏】构建高效微服务架构:Docker和Kubernetes在构建微服务架构中的应用
【4月更文挑战第27天】本文介绍了Docker和Kubernetes在构建微服务架构中的应用。Docker是开源容器引擎,用于打包和分发应用,实现隔离和封装,提升可扩展性和可维护性。Kubernetes是容器编排平台,自动化部署、扩展和管理容器,提供负载均衡和故障转移。二者结合,能高效支持微服务架构。文中通过实例展示了如何将用户、商品和订单服务用Docker打包,再用Kubernetes部署和管理,确保微服务稳定运行。

相关产品

  • 容器服务Kubernetes版