IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 系统运维 -> CentOS7利用Kubeadm快速部署Kubernetes集群 -> 正文阅读

[系统运维]CentOS7利用Kubeadm快速部署Kubernetes集群

目录

一、服务器硬件配置要求

二、kubeadm搭建k8s集群

1. 准备环境

?2. 系统初始化

3. 安装docker/kubeadm/kubelet/kubectl

4. 部署k8s主master节点

5.查看节点连接情况

?6.部署CNI网络插件

7.部署完成,查看各个节点连接状态


一、服务器硬件配置要求

  • 在开始部署k8s集群之前,服务器需要满足以下条件:
  • 一台或多台服务器,操作系统CentOS 7.x-86_x64。
  • 硬盘配置:内存2GB或更多,CPU2核或更多,硬盘30GB或更多。
  • 集群中的所有机器之间网络互通。
  • 可以访问外网,需要拉取镜像。
  • 禁止swap分区。

二、kubeadm搭建k8s集群

  • kubeadm是官方社区推出的一个用于快速部署k8s集群的工具,这个工具能通过两个命令完成一个k8s集群的部署。
  • 创建master节点:
kubeadm init
  • 将Node节点加入到当前集群中:
kubeadm join <master节点的IP和端口>

1. 准备环境

?

主机名称IP地址
k8s-master192.168.0.95
k8s-node1192.168.0.94
k8s-node2192.168.0.96

?2. 系统初始化

给各个服务器节点设置主机名
#master服务器
hostnamectl set-hostname k8s-master
#node1服务器
hostnamectl set-hostname k8s-node1
#node2服务器
hostnamectl set-hostname k8s-node1

?以下内容需要在所有服务器节点上分别执行一遍

##1.关闭防火墙
systemctl stop firewalld
systemctl disable firewall

##2.关闭selinux
sed -i 's/enforcing/disabled/' /etc/selinux/confi?

##3.关闭swap分区
sed -ri 's/.*swap.*/#&/' /etc/fstab


##5.在服务器节点添加hosts
#执行脚本
cat >> /etc/hosts << EOF
192.168.0.95 k8s-master
192.168.0.94 k8s-node1
192.168.0.96 k8s-node2
EOF

##6.将桥接得IPV4流量传递到iptables的链上
#执行脚本
cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv4.ip_forward = 1
vm.swappiness = 0
EOF

#加载modprobe br_netfilter包
modprobe br_netfilter

#查看是否加载
lsmod | grep br_netfilter

#生效
sysctl --system

#&7.同步时间
yum install ntpdate -y
ntpdate time.windows.com

##8.开启ipvs
yum -y install ipset ipvsadm

#执行脚本
cat > /etc/sysconfig/modules/ipvs.modules <<EOF
#!/bin/bash
modprobe -- ip_vs
modprobe -- ip_vs_rr
modprobe -- ip_vs_wrr
modprobe -- ip_vs_sh
modprobe -- nf_conntrack_ipv4
EOF

#授权、运行、检查是否加载
chmod 755 /etc/sysconfig/modules/ipvs.modules && bash /etc/sysconfig/modules/ipvs.modules && lsmod | grep -e ip_vs -e nf_conntrack_ipv4

#检查是否加载
lsmod | grep -e ipvs -e nf_conntrack_ipv4

3. 安装docker/kubeadm/kubelet/kubectl

?以下内容需要在所有服务器节点上分别执行一遍

##1.安装Docker
wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo

yum -y install docker-ce-18.06.3.ce-3.el7

systemctl enable docker && systemctl start docker

docker version


##2.设置Docker镜像加速器
sudo mkdir -p /etc/docker

sudo tee /etc/docker/daemon.json <<-'EOF'
{
  "exec-opts": ["native.cgroupdriver=systemd"],	
  "registry-mirrors": ["https://b9pmyelo.mirror.aliyuncs.com"]
}
EOF

sudo systemctl daemon-reload

sudo systemctl restart docker


##3.添加阿里云YUM软件源
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
##4.安装kubeadm、kubelet和kubectl
yum install -y kubelet-1.18.0 kubeadm-1.18.0 kubectl-1.18.0

vim /etc/sysconfig/kubelet
#修改
KUBELET_EXTRA_ARGS="--cgroup-driver=systemd"

systemctl enable kubelet

4. 部署k8s主master节点

##1.确定相关系统环境已准备好
swapoff -a

kubeadm reset

systemctl daemon-reload

systemctl restart kubelet

iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X 

##2.拉取阿里云镜像,并init
kubeadm init --image-repository registry.aliyuncs.com/google_containers --apiserver-advertise-address=192.168.0.95 --service-cidr=10.10.0.0/16 --pod-network-cidr=10.122.0.0/16 --ignore-preflight-errors=Swap


出现如下图所示:

????

?将红框内容分别拷贝到两个node节点服务器终端执行命令。

5.查看节点连接情况

#查看各个节点连接情况
kubectl get nodes

#(可选)默认的token有效期为24小时,当过期之后,该token就不能用了,这时可以使用如下的命令创建token:
kubeadm token create --print-join-command

#(可选)生成一个永不过期的token

kubeadm token create --ttl 0

出现如下图所示:

??

?6.部署CNI网络插件

#下载calico插件
curl https://docs.projectcalico.org/manifests/calico.yaml -O

#应用
kubectl apply -f calico.yaml

#查看部署CNI网络插件进度
kubectl get pods -n kube-system

出现如下图所示:

??

当ready都为1/1时,表示安装完毕,

7.部署完成,查看各个节点连接状态

##查看节点状态
kubectl get nodes

???

#查看集群健康状态
kubectl get cs

???

#查看集群运行状态
kubectl cluster-info

??

  系统运维 最新文章
配置小型公司网络WLAN基本业务(AC通过三层
如何在交付运维过程中建立风险底线意识,提
快速传输大文件,怎么通过网络传大文件给对
从游戏服务端角度分析移动同步(状态同步)
MySQL使用MyCat实现分库分表
如何用DWDM射频光纤技术实现200公里外的站点
国内顺畅下载k8s.gcr.io的镜像
自动化测试appium
ctfshow ssrf
Linux操作系统学习之实用指令(Centos7/8均
上一篇文章      下一篇文章      查看所有文章
加:2022-04-01 00:32:30  更:2022-04-01 00:35:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 1:34:05-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码