部署 Kubernetes 容器集群管理系统

简介: Kubernetes 是 Google 开源的容器集群管理系统,基于 Docker 构建一个容器的调度服务,提供资源调度、均衡容灾、服务注册、动态扩缩容等功能套件。基于容器的云平台。官网:https://kubernetes.io/

部署 Kubernetes 容器集群管理系统



一、 Kubernetes 和相关组件介绍


    1.Kubernetes 概述

    2.Kubernetes 架构设计图

    3.Kubernetes 常见组件介绍


二、 部署 Kubernetes 容器集群管理系统


    1.配置 Kubernetes 的 yum 源

    2.配置 Hosts 文件

    3.在各个节点上面安装 K8s 组件

    4.部署 ETCD 服务器

      1)配置 ETCD 主配置文件

      2)配置 ETCD 网络

      3)Flannel 启动过程解析

      4)配置 Flannel 服务

      5)查看子网信息

    5.部署 master 服务器

      1)配置 Kubernetes 主配置文件

      2)配置 APIServer 配置文件

      3)配置 Kube-Scheduler 配置文件

      5)配置 Flannel 服务

      6)启用 master 上 4 个服务

    6.部署 node1,node2 节点服务器

      1)配置 Flannel 服务

      2)配置 master 地址

      3)配置 Kubelet

      4)启用服务

      5)查看 Kube-Proxy 端口号

    7.在 master 上查看整个集群的运行状态


一、 Kubernetes 和相关组件介绍



1.Kubernetes 概述


Kubernetes 是 Google 开源的容器集群管理系统,基于 Docker 构建一个容器的调度服务,提供资源调度、均衡容灾、服务注册、动态扩缩容等功能套件。基于容器的云平台。官网:https://kubernetes.io/


2.Kubernetes 架构设计图


Kubernetes 是由一个 Master 和多个 Node 组成,Master 通过 API 提供服务,并接收 Kubectl 发送过来的请求来调度管理整个集群。


image.png


3.Kubernetes 常见组件介绍


  • APIServer:所有服务的统一访问入口。
  • Controller Manager(控制器):主要就是用来维持 Pod 的一个副本数。
  • Scheduler(调度器):主要就是用来分配任务到合适的节点。
  • ETCD:键值对数据库,存放了 K8s 集群中所有重要信息(持久化)
  • Kubelet:直接和容器引擎交互,用来维护容器的一个声明周期。
  • Kube-Proxy:用于将规则写入 iptables 或 IPVS 来实现服务的映射访问。
  • Kubectl:是 K8s 平台的管理命令。


二、 部署 Kubernetes 容器集群管理系统



准备工作:


image.png


image.pngimage.png


1.配置 Kubernetes 的 yum 源


把 k8s-package.tar.gz 上传到 master 机器中:


[root@master ~]# ls
anaconda-ks.cfg  k8s-package.tar.gz
[root@master ~]# tar zxf k8s-package.tar.gz 
[root@master ~]# ls
anaconda-ks.cfg  k8s-package  k8s-package.tar.gz
[root@master ~]# cat <<END > /etc/yum.repos.d/k8s.repo
[k8s]
name=k8s
baseurl=file:///root/k8s-package
enabled=1
gpgcheck=0
END


image.png


复制 K8s 的 yum 源相关文件到其他三台机器上:


[root@master ~]# scp -r /root/k8s-package 192.168.1.2:/root/
[root@master ~]# scp /etc/yum.repos.d/k8s.repo  192.168.1.2:/etc/yum.repos.d/     


2.配置 Hosts 文件


[root@master ~]# cat <<END >> /etc/hosts
192.168.1.1 master
192.168.1.2 etcd
192.168.1.3 node1
192.168.1.4 node2
END
将 hosts 文件远程复制到其他三台机器中:
[root@master ~]# scp /etc/hosts 192.168.1.2:/etc/


image.png


3.在各个节点上面安装 K8s 组件


master:


[root@master ~]# yum -y install kubernetes flannel ntp


etcd:


[root@etcd ~]# yum -y install etcd flannel ntp


node1,node2:


[root@node1 ~]# yum -y install kubernetes flannel ntp


4.部署 ETCD 服务器


1)配置 ETCD 主配置文件


[root@etcd ~]# vim /etc/etcd/etcd.conf
9 ETCD_LISTEN_CLIENT_URLS="http://localhost:2379,http://192.168.1.2:2379"
20 ETCD_ADVERTISE_CLIENT_URLS="http://192.168.1.2:2379"


image.png


[root@etcd ~]# systemctl start etcd               # 启动 ETCD 服务
[root@etcd ~]# systemctl enable etcd              # 配置 ETCD 开启自启
[root@etcd ~]# netstat -anpt | grep 2379            # 查看 ETCD 端口号
[root@etcd ~]# etcdctl member list                # 检查 ETCD 集群成员列表. 这里只有一台


image.png


2)配置 ETCD 网络


[root@etcd ~]# etcdctl mkdir /k8s/network           # 创建一个目录 /k8s/network 用于存储 flannel 网络信息
[root@etcd ~]# etcdctl set /k8s/network/config '{"Network":"10.255.0.0/16"}'  # 给 /k8s/network/config 赋一个字符串的值
[root@etcd ~]# etcdctl get /k8s/network/config          # 查看


3)Flannel 启动过程解析


  1. 从 ETCD 中获取出 /k8s/network/config 的值;
  2. 划分 subnet 子网,并在 ETCD 中进行注册;
  3. 将子网信息记录到 /run/flannel/subnet.env 中。


4)配置 Flannel 服务


[root@etcd ~]# vim /etc/sysconfig/flanneld
4 FLANNEL_ETCD_ENDPOINTS="http://192.168.1.2:2379"
8 FLANNEL_ETCD_PREFIX="/k8s/network"
11 FLANNEL_OPTIONS="--iface=ens33"


image.png


[root@etcd ~]# systemctl start flanneld
[root@etcd ~]# ifconfig


image.png


5)查看子网信息


[root@etcd ~]# cat /run/flannel/subnet.env


image.png



后面将会有一个脚本将 subnet.dev 转写成一个 docker 的环境变量文件 /run/flannel/docker;


  • docker0 的地址是由 /run/flannel/subnet.env 的 FLANNEL_SUBNET 参数决定的。


[root@etcd ~]# cat /run/flannel/docker


image.png


5.部署 master 服务器


1)配置 Kubernetes 主配置文件


[root@master ~]# vim /etc/kubernetes/config
22 KUBE_MASTER="--master=http://192.168.1.1:8080"


image.png


2)配置 APIServer 配置文件


[root@master ~]# vim /etc/kubernetes/apiserver
8 KUBE_API_ADDRESS="--insecure-bind-address=0.0.0.0"
17 KUBE_ETCD_SERVERS="--etcd-servers=http://192.168.1.2:2379"
23 KUBE_ADMISSION_CONTROL="--admission-control=AlwaysAdmit"


image.png


3)配置 Kube-Scheduler 配置文件


[root@master ~]# vim /etc/kubernetes/scheduler
7 KUBE_SCHEDULER_ARGS="0.0.0.0"


image.png


4)配置 Flannel 服务


[root@master ~]# vim /etc/sysconfig/flanneld 
4 FLANNEL_ETCD_ENDPOINTS="http://192.168.1.2:2379"
8 FLANNEL_ETCD_PREFIX="/k8s/network"
11 FLANNEL_OPTIONS="--iface=ens33"


image.png


5)启用 master 上 4 个服务


[root@master ~]# systemctl start kube-apiserver kube-controller-manager kube-scheduler flanneld       
[root@master ~]# systemctl enable kube-apiserver kube-controller-manager kube-scheduler flanneld      
[root@master ~]# ifconfig


image.png


6.部署 node1,node2 节点服务器


node1,node2 操作步骤一致:


1)配置 Flannel 服务


[root@node1 ~]# vim /etc/sysconfig/flanneld
4 FLANNEL_ETCD_ENDPOINTS="http://192.168.1.2:2379"
8 FLANNEL_ETCD_PREFIX="/k8s/network"
11 FLANNEL_OPTIONS="--iface=ens33"


image.png


2)配置 master 地址


[root@node1 ~]# vim /etc/kubernetes/config
22 KUBE_MASTER="--master=http://192.168.1.1:8080"


image.png


3)配置 Kubelet


[root@node1 ~]# vim /etc/kubernetes/kubelet
5 KUBELET_ADDRESS="--address=0.0.0.0"
11 KUBELET_HOSTNAME="--hostname-override=node1"             # node2 主机改为 node2
14 KUBELET_API_SERVER="--api-servers=http://192.168.1.1:8080"


image.png


4)启用服务


[root@node1 ~]# systemctl start flanneld kube-proxy kubelet docker 
[root@node1 ~]# systemctl enable flanneld kube-proxy kubelet docker
[root@node1 ~]# ifconfig


image.png


5)查看 Kube-Proxy 端口号


[root@node1 ~]# netstat -antp | grep proxy


image.png


7.在 master 上查看整个集群的运行状态


[root@master ~]# kubectl get nodes


image.png

相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
4月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
840 108
|
2月前
|
人工智能 算法 调度
阿里云ACK托管集群Pro版共享GPU调度操作指南
本文介绍在阿里云ACK托管集群Pro版中,如何通过共享GPU调度实现显存与算力的精细化分配,涵盖前提条件、使用限制、节点池配置及任务部署全流程,提升GPU资源利用率,适用于AI训练与推理场景。
300 1
|
2月前
|
弹性计算 监控 调度
ACK One 注册集群云端节点池升级:IDC 集群一键接入云端 GPU 算力,接入效率提升 80%
ACK One注册集群节点池实现“一键接入”,免去手动编写脚本与GPU驱动安装,支持自动扩缩容与多场景调度,大幅提升K8s集群管理效率。
263 89
|
4月前
|
运维 监控 数据可视化
小白也能部署应用,3个免费的容器化部署工具测评
本文对比了三款容器化部署工具:Docker Compose、Portainer 和 Websoft9。Docker Compose 适合开发者编排多容器应用,Portainer 提供图形化管理界面,而 Websoft9 则面向中小企业和非技术人员,提供一键部署与全流程运维支持,真正实现“开箱即用”。三款工具各有定位,Websoft9 更贴近大众用户需求。
小白也能部署应用,3个免费的容器化部署工具测评
|
2月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
505 5
|
2月前
|
存储 关系型数据库 MySQL
MySQL Docker 容器化部署全指南
MySQL是一款开源关系型数据库,广泛用于Web及企业应用。Docker容器化部署可解决环境不一致、依赖冲突问题,实现高效、隔离、轻量的MySQL服务运行,支持数据持久化与快速迁移,适用于开发、测试及生产环境。
533 5
|
4月前
|
运维 数据可视化 C++
2025 热门的 Web 化容器部署工具对比:Portainer VS Websoft9
2025年热门Web化容器部署工具对比:Portainer与Websoft9。Portainer以轻量可视化管理见长,适合技术团队运维;Websoft9则提供一站式应用部署与容器管理,内置丰富开源模板,降低中小企业部署门槛。两者各有优势,助力企业提升容器化效率。
385 1
2025 热门的 Web 化容器部署工具对比:Portainer VS Websoft9
|
3月前
|
存储 Kubernetes 持续交付
为什么Docker容器化改变了开发与部署?
为什么Docker容器化改变了开发与部署?
|
3月前
|
存储 Kubernetes 网络安全
关于阿里云 Kubernetes 容器服务(ACK)添加镜像仓库的快速说明
本文介绍了在中国大陆地区因网络限制无法正常拉取 Docker 镜像的解决方案。作者所在的阿里云 Kubernetes 集群使用的是较旧版本的 containerd(1.2x),且无法直接通过 SSH 修改节点配置,因此采用了一种无需更改 Kubernetes 配置文件的方法。通过为 `docker.io` 添加 containerd 的镜像源,并使用脚本自动修改 containerd 配置文件中的路径错误(将错误的 `cert.d` 改为 `certs.d`),最终实现了通过多个镜像站点拉取镜像。作者还提供了一个可重复运行的脚本,用于动态配置镜像源。虽然该方案能缓解镜像拉取问题,
424 2

相关产品

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

    更多