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

本文涉及的产品
容器服务 Serverless 版 ACK Serverless,317元额度 多规格
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 玩转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集群

详细教程:https://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集群

详细教程:https://kubernetes.io/zh/docs/setup/production-environment/tools/kubeadm/create-cluster-kubeadm/

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集群

详细教程:https://kind.sigs.k8s.io/docs/user/quick-start/#creating-a-cluster

基本步骤

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

实际使用

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使用教程,敬请期待!

参考:

https://www.cnblogs.com/stonezpl0202/p/15187963.html

https://www.cnblogs.com/aeolian/p/15702497.html

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

https://kind.sigs.k8s.io/docs/user/quick-start/#creating-a-cluster

https://kubernetes.io/zh/docs/setup/production-environment/tools/kubeadm/create-cluster-kubeadm/

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
1天前
|
Kubernetes Cloud Native Ubuntu
云原生之旅:Kubernetes集群搭建与应用部署
【8月更文挑战第65天】本文将带你进入云原生的世界,通过一步步指导如何在本地环境中搭建Kubernetes集群,并部署一个简单的应用。我们将使用Minikube和Docker作为工具,探索云原生技术的魅力所在。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的信息和实践技巧。
|
5天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
|
1月前
|
存储 Kubernetes 负载均衡
CentOS 7.9二进制部署K8S 1.28.3+集群实战
本文详细介绍了在CentOS 7.9上通过二进制方式部署Kubernetes 1.28.3+集群的全过程,包括环境准备、组件安装、证书生成、高可用配置以及网络插件部署等关键步骤。
181 3
CentOS 7.9二进制部署K8S 1.28.3+集群实战
|
1月前
|
Kubernetes 负载均衡 前端开发
二进制部署Kubernetes 1.23.15版本高可用集群实战
使用二进制文件部署Kubernetes 1.23.15版本高可用集群的详细教程,涵盖了从环境准备到网络插件部署的完整流程。
53 2
二进制部署Kubernetes 1.23.15版本高可用集群实战
|
1月前
|
存储 Kubernetes 测试技术
k8s使用pvc,pv,sc关联ceph集群
文章介绍了如何在Kubernetes中使用PersistentVolumeClaim (PVC)、PersistentVolume (PV) 和StorageClass (SC) 来关联Ceph集群,包括创建Ceph镜像、配置访问密钥、删除默认存储类、编写和应用资源清单、创建资源以及进行访问测试的步骤。同时,还提供了如何使用RBD动态存储类来关联Ceph集群的指南。
50 7
|
1月前
|
存储 Kubernetes 数据安全/隐私保护
k8s对接ceph集群的分布式文件系统CephFS
文章介绍了如何在Kubernetes集群中使用CephFS作为持久化存储,包括通过secretFile和secretRef两种方式进行认证和配置。
32 5
|
1月前
|
Kubernetes 负载均衡 应用服务中间件
kubeadm快速构建K8S1.28.1高可用集群
关于如何使用kubeadm快速构建Kubernetes 1.28.1高可用集群的详细教程。
49 2
|
1月前
|
Kubernetes Linux API
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
该博客文章详细介绍了在CentOS 7.6操作系统上使用kubeadm工具部署kubernetes 1.17.2版本的测试集群的过程,包括主机环境准备、安装Docker、配置kubelet、初始化集群、添加节点、部署网络插件以及配置k8s node节点管理api server服务器。
62 0
CentOS 7.6使用kubeadm部署k8s 1.17.2测试集群实战篇
|
2月前
|
API UED 开发者
超实用技巧大放送:彻底革新你的WinForms应用,从流畅动画到丝滑交互设计,全面解析如何在保证性能的同时大幅提升用户体验,让软件操作变得赏心悦目不再是梦!
【8月更文挑战第31天】在Windows平台上,使用WinForms框架开发应用程序时,如何在保持性能的同时提升用户界面的吸引力和响应性是一个常见挑战。本文探讨了在不牺牲性能的前提下实现流畅动画与交互设计的最佳实践,包括使用BackgroundWorker处理耗时任务、利用Timer控件创建简单动画,以及使用Graphics类绘制自定义图形。通过具体示例代码展示了这些技术的应用,帮助开发者显著改善用户体验,使应用程序更加吸引人和易于使用。
65 0
|
2月前
|
运维 Kubernetes Cloud Native
探索云原生:Kubernetes集群的部署与管理
【8月更文挑战第31天】 本文将带领读者深入了解云原生技术,特别是以Kubernetes为核心的集群部署和管理。文章不仅介绍了Kubernetes的基础概念和架构,还通过实际的代码示例展示了如何在云平台上搭建一个Kubernetes集群。我们将从基础的安装步骤到高级的服务部署,一步步揭示如何利用Kubernetes来简化容器化应用的管理与扩展。无论你是云原生新手还是希望提升现有技能的开发者,这篇文章都将成为你实践云原生技术的宝贵指南。
下一篇
无影云桌面