Kubernetes应用跨可用区实战

简介: 本文介绍了如何在阿里云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

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
缓存 Kubernetes Docker
GitLab Runner 全面解析:Kubernetes 环境下的应用
GitLab Runner 是 GitLab CI/CD 的核心组件,负责执行由 `.gitlab-ci.yml` 定义的任务。它支持多种执行方式(如 Shell、Docker、Kubernetes),可在不同环境中运行作业。本文详细介绍了 GitLab Runner 的基本概念、功能特点及使用方法,重点探讨了流水线缓存(以 Python 项目为例)和构建镜像的应用,特别是在 Kubernetes 环境中的配置与优化。通过合理配置缓存和镜像构建,能够显著提升 CI/CD 流水线的效率和可靠性,助力开发团队实现持续集成与交付的目标。
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
针对本地存储和 PVC 这两种容器存储使用方式,我们对 ACK 的容器存储监控功能进行了全新升级。此次更新完善了对集群中不同存储类型的监控能力,不仅对之前已有的监控大盘进行了优化,还针对不同的云存储类型,上线了全新的监控大盘,确保用户能够更好地理解和管理容器业务应用的存储资源。
699 266
|
11月前
|
存储 Kubernetes 监控
K8s集群实战:使用kubeadm和kuboard部署Kubernetes集群
总之,使用kubeadm和kuboard部署K8s集群就像回归童年一样,简单又有趣。不要忘记,技术是为人服务的,用K8s集群操控云端资源,我们不过是想在复杂的世界找寻简单。尽管部署过程可能遇到困难,但朝着简化复杂的目标,我们就能找到意义和乐趣。希望你也能利用这些工具,找到你的乐趣,满足你的需求。
1005 33
|
12月前
|
人工智能 Kubernetes 异构计算
大道至简-基于ACK的Deepseek满血版分布式推理部署实战
大道至简-基于ACK的Deepseek满血版分布式推理部署实战
690 5
|
12月前
|
Kubernetes 持续交付 开发工具
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
507 2
|
11月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
328 0
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
|
12月前
|
存储 监控 对象存储
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
ACK 容器监控存储全面更新:让您的应用运行更稳定、更透明
252 1
|
12月前
|
Kubernetes 持续交付 开发工具
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
阿里云协同万兴科技落地ACK One GitOps方案,全球多机房应用自动化发布,效率提升50%
|
12月前
|
Kubernetes 持续交付 数据库
阿里云ACK+GitLab企业级部署实战教程
GitLab 是一个功能强大的基于 Web 的 DevOps 生命周期平台,整合了源代码管理、持续集成/持续部署(CI/CD)、项目管理等多种工具。其一体化设计使得开发团队能够在同一平台上进行代码协作、自动化构建与部署及全面的项目监控,极大提升了开发效率和项目透明度。 GitLab 的优势在于其作为一体化平台减少了工具切换,高度可定制以满足不同项目需求,并拥有活跃的开源社区和企业级功能,如高级权限管理和专业的技术支持。借助这些优势,GitLab 成为许多开发团队首选的 DevOps 工具,实现从代码编写到生产部署的全流程自动化和优化。
|
存储 监控 对象存储
ACK容器监控存储全面更新:让您的应用运行更稳定、更透明
介绍升级之后的ACK容器监控体系,包括各大盘界面展示和概要介绍。

热门文章

最新文章

相关产品

  • 容器服务Kubernetes版
  • 推荐镜像

    更多