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

应用跨多个可用区

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

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

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

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

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

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

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

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

ECS的可用区标签

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

这是可用区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/zoneoperator: Invalues:- cn-hangzhou-b- cn-hangzhou-f

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

apiVersion: extensions/v1beta1
kind: Deployment
metadata:name: nginx-multi-zone
spec:replicas: 6selector:matchLabels:app: nginx-multi-zonetemplate:metadata:labels:app: nginx-multi-zonespec:affinity:nodeAffinity:requiredDuringSchedulingIgnoredDuringExecution:nodeSelectorTerms:- matchExpressions:- key: failure-domain.beta.kubernetes.io/zoneoperator: Invalues:- cn-hangzhou-b- cn-hangzhou-fcontainers:- name: nginx-multi-zoneimage: nginx:latestports:- 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集群右侧的下拉菜单,可以看到如下界面:

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

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

小结

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

Kubernetes应用跨可用区实战相关推荐

  1. 玩转ECS第6讲 | 弹性计算Region化部署和跨可用区容灾介绍

    简介:本次分享由阿里云弹性计算架构负责人李钟(谢顿)为大家介绍阿里云region化部署和跨可用区容灾的实践经验,说明多Region部署场景中使用阿里云弹性计算的最佳实践,并结合弹性计算的实践经验探讨如 ...

  2. SAP云上自适应跨可用区高可用方案

      SAP云上跨可用区高可用架构现状 在SAP云上官方架构设计指引中,展示了如何利用其多可用区的技术优势.诸如Route 53.NLB等基础设施服务以及SAP或操作系统的高可用技术实现端到端的跨可用区 ...

  3. 玩转ECS第6讲 | 弹性计算 Region 化部署和跨可用区容灾介绍

    本次分享主要围绕以下三个方面: 一.Region和可用区介绍 二.Endpoints和资源作用域 三.多可用区容灾和Region化部署 弹性计算Region化部署和跨可用区容灾本身是非常复杂的课题,本 ...

  4. QQ空间迁移_【阿里云跨可用区迁移】

    阿里云跨可用区迁移 2016-04-09 10:37:42 是. 第一步 迁移前准备工作,创建一个网络结构,安全规则一模一样的VPC网络 除可用区不一样,其他网段信息都一样. 安全组,以及安全组内的规 ...

  5. 阿里云崩“出圈”了!保护业务还得加一道同云跨可用区容灾!

    2022年12月18日,上午10点47分,阿里云的香港部分服务出现故障,导致多个香港及澳门站点受到影响. 随后阿里云方面发布公告表示,阿里云官网 12 月 18 日下午更新处理进展称,经排查,阿里云香 ...

  6. Pod在多可用区worker节点上的高可用部署

    一.      需求分析 当前kubernetes集群中的worker节点可以支持添加多可用区中的ECS,这种部署方式的目的是可以让一个应用的多个pod(至少两个)能够分布在不同的可用区,起码不能分布 ...

  7. Pod在多可用区worker节点上的高可用部署 1

    一.      需求分析 当前kubernetes集群中的worker节点可以支持添加多可用区中的ECS,这种部署方式的目的是可以让一个应用的多个pod(至少两个)能够分布在不同的可用区,起码不能分布 ...

  8. 节点部署_Pod在多可用区worker节点上的高可用部署

    一. 需求分析 当前kubernetes集群中的worker节点可以支持添加多可用区中的ECS,这种部署方式的目的是可以让一个应用的多个pod(至少两个)能够分布在不同的可用区,起码不能分布在同一个可 ...

  9. Redis如何实现多可用区?

    在如今的业务场景下,高可用性要求越来越高,核心业务跨可用区已然成为标配.腾讯云数据库高级工程师刘家文结合腾讯云数据库的内核实战经验,给大家分享Redis是如何实现多可用区,内容包含 Redis主从版. ...

最新文章

  1. 深度学习 vs SLAM
  2. CTF(Pwn) 当题目为我们提供Libc版本.so文件, 与 不提供的区别
  3. tomcat的安装和部署项目
  4. springboot md5加密_SpringSecurity入门-SpringBoot集成SpringSecurity
  5. Asp.Net Core 工作单元 UnitOfWork UOW
  6. 超实用编程技术指南!为什么你还学不会一门编程语言?
  7. python 菜鸟:返回值_Python中的真实值和虚假值:详细介绍
  8. Linux内核的文档管理工具:Sphinx
  9. django Error: That port is already in use.
  10. 计算机专业创新项目,计算机专业本科生的创新思维
  11. iOS基础 - UIDynamic
  12. 创投观察 | 市场白热化前,RPA公司要怎么构建核心壁垒?
  13. 如何快速搭建在线教育知识付费系统(附带源码)
  14. 最全jar包下载链接
  15. CAPL学习之路-SOME/IP相关函数
  16. java电影购票系统_Java Swing实现电影购票系统项目
  17. MineCraft建模工具
  18. light动名词_动名词的用法英语语法大全
  19. 原生JS实现记忆翻牌小游戏
  20. 以P2P网贷为例互联网金融产品如何利用大数据做风控?

热门文章

  1. [教程]centos卸载、安装mysql(源码编译安装方式)
  2. Javascript中for循环别名
  3. Mono for Android 4.2初探
  4. 从留言簿开始,学习MonoRail MVC(三)
  5. 转 Spring源码剖析——核心IOC容器原理
  6. selenium定位不到元素的原因。
  7. gravatar配置和使用【让你的网站使用全球通用头像】
  8. quot;数据结构翻转课堂quot;答疑实录——链表
  9. Linux shell逐行读取文件的方法
  10. OpenCV搜索文件夹中的图片并保存图片路径和信息