玩转Kubernetes—尝试以不同方式初始化集群

简介: 玩转Kubernetes—尝试以不同方式初始化集群

前提说明

实验使用的操作系统版本: Ubuntu 18.04 LTS (GNU/Linux 4.15.0-175-generic x86_64)

Kubernetes(工具)版本:kubectl v1.22.3 、 kubeadm v1.22.3 、kubelet v1.22.3、minikube、kind v0.12.0

1 环境准备

1.1 Ubuntu虚拟机

具体步骤可以省略了吧,不会的可以留言下哦

1.2 Ubuntu安装Docker

(1)安装步骤

  • 查看操作系统版本和Linux内核版本是否符合要求
$ lsb_release -a
$ cat /proc/version
复制代码
  • 删除旧版本Docker
$ sudo apt-get remove docker docker-engine docker.io containerd runc
复制代码
  • 更新apt仓库
$ sudo apt-get update
复制代码
  • 安装一些可能用到的插件
$ sudo apt-get install \
     ca-certificates \
     curl \
     gnupg \
     lsb-release
复制代码
  • 添加Docker官方的gpg密钥
$ curl -fsSL https://download.docker.com/linux/ubuntu/gpg | sudo gpg --dearmor -o /usr/share/keyrings/docker-archive-keyring.gpg
复制代码
  • 设置stable仓库
$ echo \
  "deb [arch=$(dpkg --print-architecture) signed-by=/usr/share/keyrings/docker-archive-keyring.gpg] https://download.docker.com/linux/ubuntu \
  $(lsb_release -cs) stable" | sudo tee /etc/apt/sources.list.d/docker.list > /dev/null
复制代码
  • 更新apt仓库,安装最新版本的Docker Engine和containerd
$ sudo apt-get update
$ sudo apt-get install docker-ce docker-ce-cli containerd.io
复制代码

(2)具体操作

yanmingxin@machine:~$ lsb_release -a
No LSB modules are available.
Distributor ID: Ubuntu
Description:  Ubuntu 18.04 LTS
Release:  18.04
Codename: bionic
yanmingxin@machine:~$ cat /proc/version
Linux version 4.15.0-20-generic (buildd@lgw01-amd64-039) (gcc version 7.3.0 (Ubuntu 7.3.0-16ubuntu3))
yanmingxin@machine:~$ sudo apt-get remove docker docker-engine docker.io containerd runc
[sudo] yanmingxin 的密码: 
......
yanmingxin@machine:~$ sudo apt-get update
......
正在读取软件包列表... 完成   
yanmingxin@machine:~$ sudo apt-get install \
>     ca-certificates \
>     curl \
>     gnupg \
>     lsb-release
.... 篇幅过长,以下省略
复制代码

1.3 Ubuntu安装kubectl、kubeadm、kubelet、kind、minikube

1.3.1 kubectl、kubeadm、 kubelet

更新 apt 包索引,并安装使用 Kubernetes apt 仓库所需要的包:

$ sudo apt-get update
$ sudo apt-get install -y apt-transport-https ca-certificates curl
复制代码

下载 Google Cloud 公开签名秘钥:

$ sudo curl -fsSLo /usr/share/keyrings/kubernetes-archive-keyring.gpg https://packages.cloud.google.com/apt/doc/apt-key.gpgc
复制代码

添加 Kubernetes apt 仓库:

$ echo "deb [signed-by=/usr/share/keyrings/kubernetes-archive-keyring.gpg] https://apt.kubernetes.io/ kubernetes-xenial main" | sudo tee /etc/apt/sources.list.d/kubernetes.list
复制代码

更新 apt 包索引,使之包含新的仓库并安装 kubectl:

$ sudo apt-get update
$ sudo  apt install kubeadm=1.22.3-00
$ sudo  apt install kubectl=1.22.3-00
$ sudo  apt install kubelet=1.22.3-00
复制代码

PS:如果要卸载当前版本安装其他版本,可以停止进程并先执行:

apt remove kubelet kubectl kubeadm

再按照上述步骤进行安装

1.3.2 kind
$ curl -Lo ./kind https://kind.sigs.k8s.io/dl/v0.12.0/kind-linux-amd64
复制代码

再将下载的文件放到环境变量$PATH所在的目录下

1.3.3 minikube
$ curl -LO https://storage.googleapis.com/minikube/releases/latest/minikube-linux-amd64
$ sudo install minikube-linux-amd64 /usr/local/bin/minikube
复制代码

2 使用minikube部署Kubernetes集群

详细教程:minikube.sigs.k8s.io/docs/start/

总结大致步骤

  • 根据镜像创建Deployment(Deployment 是管理应用副本的 API 对象,通常通过运行没有本地状态的Pods来实现。)
  • 部署Node并暴露端口
  • 进行服务访问测试
  • 查看状态
root@machine:/home/yanmingxin# kubectl create deployment hello-minikube --image=k8s.gcr.io/echoserver:1.4
deployment.apps/hello-minikube created
root@machine:/home/yanmingxin# kubectl expose deployment hello-minikube --type=NodePort --port=8080
service/hello-minikube exposed
root@machine:/home/yanmingxin# kubectl get services hello-minikube
NAME             TYPE       CLUSTER-IP      EXTERNAL-IP   PORT(S)          AGE
hello-minikube   NodePort   10.12.19.101    <none>        8080:31555/TCP   8s
root@machine:/home/yanmingxin# minikube service hello-minikube
root@machine:/home/yanmingxin# kubectl port-forward service/hello-minikube 7080:8080
Forwarding from 127.0.0.1:7080 -> 8080
Forwarding from [::1]:7080 -> 8080
复制代码

启动另一个终端测试

root@machine:/home/yanmingxin# curl http://localhost:7080/
CLIENT VALUES:
client_address=127.0.0.1
command=GET
real path=/
......
root@machine:/home/yanmingxin# kubectl get po -A
NAMESPACE     NAME                               READY   STATUS    RESTARTS      AGE
default       hello-minikube-xxxxxxxxx   1/1     Running   0             26m
复制代码

3 使用kubeadm一键部署Kubernetes集群

详细教程:kubernetes.io/zh/docs/set…

3.1 简单说明

此次使用kubeadm是使用yaml文件的方式,以下是在网上找的具体步骤和一些创建集群过程说明和排错积累的经验:

(1)基本步骤:

  • 编写所需集群yaml文件
  • 根据yaml文件初始化Kubernetes集群
  • 做集群配置
  • 查看和管理集群

(2)需要注意的地方

  • 针对比较新版本(可能在1.20.x以上)的kubeadm,使用yum 安装kubeadm和docker后,这俩使用的cgroup驱动不一致。需要在指定docker的cgroup驱动为system。添加如下配置文件,并重启docker
vim /etc/docker/daemon.json
# 文件内容:
{
    "exec-opts": ["native.cgroupdriver=systemd"],
    "log-driver": "json-file",
    "log-opts": {
            "max-size": "100m"
    }
}
复制代码
  • kubeadm初始化集群需要在root权限下进行,并且要禁用swap分区

3.2 具体操作

root@machine:/home/yanmingxin/k8s_learn# vim kubeadm.yaml
#----------- 文件内容------------
apiVersion: kubeadm.k8s.io/v1beta3  #版本
kind: ClusterConfiguration
kubernetesVersion: 1.22.3  #版本,与kubeadm对应
imageRepository: registry.aliyuncs.com/google_containers #配置国内镜像
apiServer:
  extraArgs:
    runtime-config: "api/all=true"
controllerManager:
  extraArgs:
    horizontal-pod-autoscaler-sync-period: "10s"
    node-monitor-grace-period: "10s"  
etcd:
  local:
    dataDir: /data/k8s/etcd
#----------- 文件内容------------
root@machine:/home/yanmingxin/k8s_learn# kubeadm init --config kubeadm.yaml
[init] Using Kubernetes version: v1.22.3
......
Your Kubernetes control-plane has initialized successfully!
......
root@machine:/home/yanmingxin/k8s_learn# mkdir -p $HOME/.kube
root@machine:/home/yanmingxin/k8s_learn# sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
root@machine:/home/yanmingxin/k8s_learn# sudo chown $(id -u):$(id -g) $HOME/.kube/config
root@machine:/home/yanmingxin/k8s_learn# kubectl get nodes
NAME                 STATUS   ROLES                  AGE     VERSION
kind-control-plane   Ready    control-plane,master   6s      v1.23.4
复制代码

PS:如果配置文件或版本导致集群初始化报错,可以使用kubeadm reset -f命令进行重置操作,会清除相关文件,生产环境下慎用!!!

4 使用kind部署Kubernetes集群

详细教程:kind.sigs.k8s.io/docs/user/q…

基本步骤

  • 构建镜像
  • 使用镜像初始化集群
  • 查看和管理集群

实际使用

root@machine:/usr# kind create cluster 
Creating cluster "kind" ...
 ✓ Ensuring node image (kindest/node:v1.23.4) 🖼 
 ✓ Preparing nodes 📦  
 ✓ Writing configuration 📜 
 ✓ Starting control-plane 🕹️ 
 ✓ Installing CNI 🔌 
 ✓ Installing StorageClass 💾 
......
root@machine:/usr# kind get clusters
kind
root@machine:/usr# kind create cluster --name kind-2
Creating cluster "kind" ...
 ✓ Ensuring node image (kindest/node:v1.23.4) 🖼 
 ✓ Preparing nodes 📦  
 ✓ Writing configuration 📜 
 ✓ Starting control-plane 🕹️ 
 ✓ Installing CNI 🔌 
 ✓ Installing StorageClass 💾 
......
root@machine:/usr/local# kind get clusters
kind
kind-2
复制代码

PS:由以上简单的使用我们发现了什么?

网络异常,图片无法展示
|


仔细看下这个过程,再回顾下我们上节学习的Kubernetes组件,发现了Kubernetes集群的初始化创建过程并不是那么庞然大物,也是从一个镜像的构建,到节点的初始化再到配置的引入一步一步进行的,由小到大的进行。

5 总结

回顾一下,因为本人也是初次学习,由于环境限制和经验的不足,对Kubernetes集群初始化的演示过程比较的片面和笼统,因此还希望读者能见谅并指出不足,当然相比集群的搭建过程,对基础知识和概念的掌握和实际的使用可能更为重要,所以下次争取发一次比较精细化的Kubernetes使用教程,敬请期待!

参考:

www.cnblogs.com/stonezpl020…

www.cnblogs.com/aeolian/p/1…

minikube.sigs.k8s.io/docs/start/

kind.sigs.k8s.io/docs/user/q…

kubernetes.io/zh/docs/set…



相关实践学习
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。 &nbsp; &nbsp; 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
4月前
|
资源调度 Kubernetes 调度
从单集群到多集群的快速无损转型:ACK One 多集群应用分发
ACK One 的多集群应用分发,可以最小成本地结合您已有的单集群 CD 系统,无需对原先应用资源 YAML 进行修改,即可快速构建成多集群的 CD 系统,并同时获得强大的多集群资源调度和分发的能力。
149 9
|
4月前
|
资源调度 Kubernetes 调度
从单集群到多集群的快速无损转型:ACK One 多集群应用分发
本文介绍如何利用阿里云的分布式云容器平台ACK One的多集群应用分发功能,结合云效CD能力,快速将单集群CD系统升级为多集群CD系统。通过增加分发策略(PropagationPolicy)和差异化策略(OverridePolicy),并修改单集群kubeconfig为舰队kubeconfig,可实现无损改造。该方案具备多地域多集群智能资源调度、重调度及故障迁移等能力,帮助用户提升业务效率与可靠性。
|
6月前
|
存储 Kubernetes 监控
K8s集群实战:使用kubeadm和kuboard部署Kubernetes集群
总之,使用kubeadm和kuboard部署K8s集群就像回归童年一样,简单又有趣。不要忘记,技术是为人服务的,用K8s集群操控云端资源,我们不过是想在复杂的世界找寻简单。尽管部署过程可能遇到困难,但朝着简化复杂的目标,我们就能找到意义和乐趣。希望你也能利用这些工具,找到你的乐趣,满足你的需求。
590 33
|
6月前
|
Kubernetes 开发者 Docker
集群部署:使用Rancher部署Kubernetes集群。
以上就是使用 Rancher 部署 Kubernetes 集群的流程。使用 Rancher 和 Kubernetes,开发者可以受益于灵活性和可扩展性,允许他们在多种环境中运行多种应用,同时利用自动化工具使工作负载更加高效。
333 19
|
6月前
|
人工智能 分布式计算 调度
打破资源边界、告别资源浪费:ACK One 多集群Spark和AI作业调度
ACK One多集群Spark作业调度,可以帮助您在不影响集群中正在运行的在线业务的前提下,打破资源边界,根据各集群实际剩余资源来进行调度,最大化您多集群中闲置资源的利用率。
|
9月前
|
Prometheus Kubernetes 监控
OpenAI故障复盘 - 阿里云容器服务与可观测产品如何保障大规模K8s集群稳定性
聚焦近日OpenAI的大规模K8s集群故障,介绍阿里云容器服务与可观测团队在大规模K8s场景下我们的建设与沉淀。以及分享对类似故障问题的应对方案:包括在K8s和Prometheus的高可用架构设计方面、事前事后的稳定性保障体系方面。
|
6月前
|
Prometheus Kubernetes 监控
OpenAI故障复盘丨如何保障大规模K8s集群稳定性
OpenAI故障复盘丨如何保障大规模K8s集群稳定性
198 0
OpenAI故障复盘丨如何保障大规模K8s集群稳定性
|
8月前
|
缓存 容灾 网络协议
ACK One多集群网关:实现高效容灾方案
ACK One多集群网关可以帮助您快速构建同城跨AZ多活容灾系统、混合云同城跨AZ多活容灾系统,以及异地容灾系统。
|
7月前
|
运维 分布式计算 Kubernetes
ACK One多集群Service帮助大批量应用跨集群无缝迁移
ACK One多集群Service可以帮助您,在无需关注服务间的依赖,和最小化迁移风险的前提下,完成跨集群无缝迁移大批量应用。
|
9月前
|
Kubernetes Ubuntu 网络安全
ubuntu使用kubeadm搭建k8s集群
通过以上步骤,您可以在 Ubuntu 系统上使用 kubeadm 成功搭建一个 Kubernetes 集群。本文详细介绍了从环境准备、安装 Kubernetes 组件、初始化集群到管理和使用集群的完整过程,希望对您有所帮助。在实际应用中,您可以根据具体需求调整配置,进一步优化集群性能和安全性。
647 13

推荐镜像

更多