玩转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)
玩转Kubernetes—尝试以不同方式初始化集群相关推荐
- 学习笔记之-Kubernetes(K8S)介绍,集群环境搭建,Pod详解,Pod控制器详解,Service详解,数据存储,安全认证,DashBoard
笔记来源于观看黑马程序员Kubernetes(K8S)教程 第一章 kubernetes介绍 应用部署方式演变 在部署应用程序的方式上,主要经历了三个时代: 传统部署:互联网早期,会直接将应用程序部署 ...
- Kubernetes(三):k8s集群部署之kubeadm
k8s部署环境 公有云环境:AWS.腾讯云.阿里云等等 私有云:OpenStack.vSphere等 Baremetal环境:物理服务器或独立虚拟机(底层没有云环境). k8s部署方式 Mini ...
- Kubernetes 系列之 kubeadm 搭建k8s集群
Kubeadm 搭建k8s集群 注意:Kubernetes 系列 所采用的kuberntetes版本都是 1.15+ 1 Master 节点安装 1.1 系统环境配置 1.1.1 设置主机名称 hos ...
- Kubernetes(k8s)入门及集群部署文档
文章目录 一.k8s 快速入门 简介 部署方式的进化 k8s能做什么 架构 整体主从方式 Master 节点架构 Node 节点架构 概念 快速体验 流程叙述 二.k8s 集群安装 前置要求 了解ku ...
- kubernetes中mysql乱码_在kubernetes中部署tomcat与mysql集群-Go语言中文社区
在kubernetes中部署tomcat与mysql集群之前必须要有以下这些基础: 1. 已安装.配置kubernetes 2. 集群中有tomcat与mysql容器镜像 3. 有docker基础 具 ...
- k8s初始化集群后kubectl get nodes错误
刚刚初始化集群,想查看一下节点状态,显示refused [root@master01 ~]# kubectl get nodes The connection to the server localh ...
- kubeadm初始化集群报错:kubelet driver: “cgroupfs“ is different from docker cgroup driver: “systemd“
kubeadm初始化集群报错: 报错信息如下: [kubelet-check] It seems like the kubelet isn't running or healthy. [kubel ...
- 企业实战-Kubernetes(十四)k8s高可用集群
k8s高可用集群 1 使用pacemaker搭建k8s的高可用(haproxy的高可用) 安装并配置haproxy 安装并配置pacemaker 2 k8s集群部署 master准备 三个结点关闭交换 ...
- PostgreSQL安装初始化集群失败
PostgreSQL安装初始化集群失败 文章目录 前言 一.造成原因有什么? 二.解决步骤 1.首先查看系统用户,是否存在postgres用户 2.没有postgres用户便创建postgres用户 ...
最新文章
- 算法(第四版)C# 习题题解——1.3
- 这款AI语音模型让派大星承认自己是钢铁侠,造假小扎对口型,火到挤爆服务器|在线可玩...
- 双智机器人 珠海_美的集团:“双智”战略加速推行,加强发展机器人业务
- ELK logstash 配置自定义字段为索引
- VTK:隐式函数之BooleanOperationImplicitFunctions
- 格式化字符串漏洞利用 七、工具
- Java删除ArrayList中的重复元素的2种方法
- JAVAWeb项目 微型商城项目-------(三)导包及工具类的准备
- python27的Windows下环境搭建
- PHP与JS互相加密解密方法2.0
- Cocos2d-x手机游戏开发视频教程
- 万里汇WorldFirst支持从PayPal提现美元(实战教程)
- cwrsync从linux同步文件数据到windows
- android仿今日头条App、多种漂亮加载效果、选择器汇总、记事本App、Kotlin开发等源码
- 如何制作自己的网站?
- 电子学会-全国青少年编程等级考试真题Scratch一级(2019年3月)
- Catching Cheaters (LCS变形)
- osm数据下载 python_osm数据下载 python_批量下载osm的分区域的osm文件
- Python3学习笔记(二)by Learn Python 3 the HARD WAY
- 中国状元”在美国读大学后对中国教育的感悟
热门文章
- vncserver密码修改
- csgo 机器人模式_csgo怎么单机跟电脑打只有每队5人,怎么增加BOT
- 手机写python工具_GitHub - littleningmeng/pyphone: Python实现的安卓手机投屏工具
- python+OpenCV笔记(二十四):Shi-Tomasi角点检测
- 计算机网络量化噪音是怎么消除的,数字图像噪声消除算法研究(可编辑).doc
- linux发行版中的i386/i686/x86-64/有什么区别?
- C++:二维数组参数传递
- idea为web项目添加tomcat并配置Artifacts
- Mysql的基本函数--与自定义函数
- 音频 ----- DRC