Kubernetes-使用rancher搭建Kubernetes高可用集群

简介: 引言  之前我写了一篇文章介绍了离线部署Kubernetes 1.9.0,当时搭建的是1+3模式,此种模式不适合用于生产,为了防止由于master节点宕机造成集群不能正常工作的问题,推荐搭建Kubernetes高可用集群,本篇文章将介绍如何使用rancher搭建Kubernetes高可用集群。

引言


  之前我写了一篇文章介绍了离线部署Kubernetes 1.9.0,当时搭建的是1+3模式,此种模式不适合用于生产,为了防止由于master节点宕机造成集群不能正常工作的问题,推荐搭建Kubernetes高可用集群,本篇文章将介绍如何使用rancher搭建Kubernetes高可用集群。

准备工作


  1. 集群机器

首先准备搭建集群环境的机器,笔者准备的集群机器如下:

Hostname IP Memory OS Role
k8smaster1 192.168.246.128 6G CentOS 7.5 Kubernetes master 节点
k8smaster2 192.168.246.129 6G CentOS 7.5 Kubernetes master 节点
k8smaster3 192.168.246.130 6G CentOS 7.5 Kubernetes master 节点
k8sworker1 192.168.246.131 12G CentOS 7.5 Kubernetes node 节点
k8sworker2 192.168.246.132 12G CentOS 7.5 Kubernetes node 节点
k8sworker3 192.168.246.133 12G CentOS 7.5 Kubernetes node 节点
k8sworker4 192.168.246.134 12G CentOS 7.5 Kubernetes node 节点
k8sworker5 192.168.246.135 12G CentOS 7.5 Kubernetes node 节点
  1. 软件版本
    2.1 rancher
    截止写这篇文章时,rancher的最新版本是v2.0.8,所以我使用的v2.0.8的稳定版,这里还要关注一下v2.0.8版本对软硬件的要求,在GitHub上可以看到对于环境的最低要求:
  • 操作系统
    Ubuntu 16.04 (64-bit)
    Red Hat Enterprise Linux 7.5 (64-bit)
    RancherOS 1.3 (64-bit)
  • 硬件
    至少4 GB内存
  • 软件
    Docker版本:v1.12.6, 1.13.1, 17.03.2

2.2 Kubernetes
Kubernetes的版本需要根据rancher来定,在rancher v2.0.8 release notes中说明了推荐使用1.11.2版本的Kubernetes;

img_203698f67999022ffab41a1a7d90fffd.png
rancher release notes

2.3 Docker
Docker的版本需要根据Kubernetes来定,在Kubernetes 1.11 change log中描述如下,和1.10版本一样,经过验证的Docker版本有1.11.2 至 1.13.1 和 17.03.x;

img_3ad6c8fcd993a94f9e7fafd6f2deba8b.png
Kubernetes change log
  1. 环境配置
    3.1 修改每台机器的【/etc/hosts】文件,增加以下解析:
192.168.246.128 k8smaster1
192.168.246.129 k8smaster2
192.168.246.130 k8smaster3
192.168.246.131 k8sworker1
192.168.246.132 k8sworker2
192.168.246.133 k8sworker3
192.168.246.134 k8sworker4
192.168.246.135 k8sworker5

3.2 关闭所有机器的安全加强系统SELinux,使容器能够访问到宿主机文件系统

vim /etc/selinux/config

将【SELINUX】设置为【disabled】

img_3dfbf4cd39340de21f91c93070827675.png
关闭selinux.png

临时关闭SELinux

setenforce 0

3.3 关闭虚拟内存
修改配置文件【/etc/fstab】

vim /etc/fstab

  注释掉swap那一行

img_3d2b6b7a21b505173865232079255e41.png
image.png

  然后通过命令临时关闭虚拟内存

swapoff -a

关于不关闭虚拟内存会出现的问题我在离线部署Kubernetes 1.9.0已经注明;
3.4 设置防火墙
  如果是做测试用,可以直接关掉防火墙,但是如果是用于生产环境,还是老老实实的去设置需要开发的端口吧,运行以下命令关闭防火墙

systemctl stop firewalld.service && systemctl disable firewalld.service

3.5 安装docker
选择docker版本【docker 17.03.2-ce】,安装步骤参考这里,或者也可以选择直接运行下面的命令

mv /etc/yum.repos.d/CentOS-Base.repo /etc/yum.repos.d/CentOS-Base.repo.bak
curl -o /etc/yum.repos.d/CentOS-Base-Ali.repo http://mirrors.aliyun.com/repo/Centos-7.repo
curl -o /etc/yum.repos.d/CentOS-Base-163.repo https://mirrors.163.com/.help/CentOS7-Base-163.repo
curl -o /etc/yum.repos.d/Docker-ce-Ali.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
yum makecache
yum install --setopt=obsoletes=0 docker-ce-17.03.2.ce-1.el7.centos docker-ce-selinux-17.03.2.ce-1.el7.centos.noarch -y
systemctl enable docker.service && systemctl start docker.service

部署rancher


  rancher的部署有两种方式,分别是单点部署和高可用部署,由于本文的重点在于如何使用rancher搭建Kubernetes高可用集群,所以本文使用rancher的单点部署方式,至于rancher的高可用部署,以后再写文章补充。
选择一个节点(我选择的是k8smaster1节点)运行如下命令安装单节点rancher:

docker run -d --restart=unless-stopped -p 80:80 -p 443:443 rancher/rancher:stable

安装完成后运行【docker ps】会看到有一个rancher的容器

img_77fe3e262588d3c53b9996f05d2a386d.png
install rancher

现在通过浏览器访问【https://192.168.246.128/】会发现跳转到了【https://192.168.246.128/update-password】,让我们为admin用户设置一个密码:

img_775c6eee38d9aed7bf37f305c7244623.png
update password

接着设置访问rancher的URL,需要能够被所有的节点访问到,这里你可以设置成【rancher.{domain.com}】:

img_978d4841e63b93086b5cc1119ed57d8c.png
set URL

设置完成后点击【Save URL】,然后就进入添加集群的页面了

img_440a9bceeecffcbb7a3a82663cacc490.png
add cluster

点击【Add Cluster】添加集群,选择【CUSTOM】:

img_a24641f730607ead7e467704aa840890.png
Select custom

填写集群名称,然后展开【Cluster Options】,设置集群配置,网络提供者选择Flannel

img_3af64ae72a24567539d3cf35cdbfa452.png
Cluster Options

设置完成后点击【Next】按钮,就可以看到添加Node命令的界面了,根据节点的角色进行选择,我的主节点的角色选择是etcd+Control Plane,工作节点的角色选择是Worker,选择完后就会看到下面生成的命令,将命令Copy到相应的节点运行就可以了

img_45560e74e47f947ceb4152de9fc252dd.png
Select Node Role

然后点到【Cluster】就会看到集群正在准备环境(Provisioning),你现在要做的就是等待

img_ee2400be326b1ccace745e69a4939c6b.png
Provisioning

等到所有的节点都添加完成之后就能看到集群的状态已经变成【Active】了,然后就可以部署你的应用了。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
1月前
|
缓存 容灾 网络协议
ACK One多集群网关:实现高效容灾方案
ACK One多集群网关可以帮助您快速构建同城跨AZ多活容灾系统、混合云同城跨AZ多活容灾系统,以及异地容灾系统。
|
2月前
|
Kubernetes Ubuntu 网络安全
ubuntu使用kubeadm搭建k8s集群
通过以上步骤,您可以在 Ubuntu 系统上使用 kubeadm 成功搭建一个 Kubernetes 集群。本文详细介绍了从环境准备、安装 Kubernetes 组件、初始化集群到管理和使用集群的完整过程,希望对您有所帮助。在实际应用中,您可以根据具体需求调整配置,进一步优化集群性能和安全性。
148 12
|
2月前
|
Prometheus Kubernetes 监控
OpenAI故障复盘 - 阿里云容器服务与可观测产品如何保障大规模K8s集群稳定性
聚焦近日OpenAI的大规模K8s集群故障,介绍阿里云容器服务与可观测团队在大规模K8s场景下我们的建设与沉淀。以及分享对类似故障问题的应对方案:包括在K8s和Prometheus的高可用架构设计方面、事前事后的稳定性保障体系方面。
|
2月前
|
Kubernetes 网络协议 应用服务中间件
Kubernetes Ingress:灵活的集群外部网络访问的利器
《Kubernetes Ingress:集群外部访问的利器-打造灵活的集群网络》介绍了如何通过Ingress实现Kubernetes集群的外部访问。前提条件是已拥有Kubernetes集群并安装了kubectl工具。文章详细讲解了Ingress的基本组成(Ingress Controller和资源对象),选择合适的版本,以及具体的安装步骤,如下载配置文件、部署Nginx Ingress Controller等。此外,还提供了常见问题的解决方案,例如镜像下载失败的应对措施。最后,通过部署示例应用展示了Ingress的实际使用方法。
87 2
|
2月前
|
Kubernetes 容灾 调度
阿里云 ACK 高可用稳定性最佳实践
本文整理自2024云栖大会刘佳旭的演讲,主题为《ACK高可用稳定性最佳实践》。文章探讨了云原生高可用架构的重要性,通过Kubernetes的高可用案例分析,介绍了ACK在单集群高可用架构设计、产品能力和最佳实践方面的方法,包括控制面和数据面的高可用策略、工作负载高可用配置、企业版容器镜像服务高可用配置等内容,旨在帮助企业构建更加可靠和高效的应用运行环境。
|
2月前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。
|
3月前
|
Kubernetes 监控 Cloud Native
Kubernetes集群的高可用性与伸缩性实践
Kubernetes集群的高可用性与伸缩性实践
99 1
|
4月前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景
|
3月前
|
Kubernetes 关系型数据库 MySQL
Kubernetes入门:搭建高可用微服务架构
【10月更文挑战第25天】在快速发展的云计算时代,微服务架构因其灵活性和可扩展性备受青睐。本文通过一个案例分析,展示了如何使用Kubernetes将传统Java Web应用迁移到Kubernetes平台并改造成微服务架构。通过定义Kubernetes服务、创建MySQL的Deployment/RC、改造Web应用以及部署Web应用,最终实现了高可用的微服务架构。Kubernetes不仅提供了服务发现和负载均衡的能力,还通过各种资源管理工具,提升了系统的可扩展性和容错性。
198 3
|
4月前
|
Kubernetes 持续交付 开发工具
ACK One GitOps:ApplicationSet UI简化多集群GitOps应用管理
ACK One GitOps新发布了多集群应用控制台,支持管理Argo CD ApplicationSet,提升大规模应用和集群的多集群GitOps应用分发管理体验。

热门文章

最新文章