K8S -----二进制搭建 Kubernetes v1.20

目录

一、准备环境

1.1 修改主机名

1.2 关闭防火墙(三台一起,这里只展示master01)

1.3 在master添加hosts(依旧是三台一起)

1.4 调整内核参数并开启网桥模式

二、部署docker引擎

三、部署 etcd 集群 

1.在master01节点上操作

2.生成Etcd证书

1.创建目录

2.创建用于生成CA证书、etcd 服务器证书以及私钥的目录

3.拷贝服务端

4.把etcd相关证书文件、命令文件和服务管理文件全部拷贝到另外两个etcd集群节点

3.在 node01 节点上操作

同理node2也是同样操作

来到master01上检查etcd群集状态

四、部署Master组件

1.在 master01 节点上操作

1.1创建kubernetes工作目录

1.2 创建用于生成CA证书、相关组件的证书和私钥的目录

1.3上传 kubernetes-server-linux-amd64.tar.gz 到 /opt/k8s/ 目录中,解压 kubernetes 压缩包 ​编辑

1.4 复制master组件的关键命令文件到 kubernetes工作目录的 bin 子目录中

1.5 创建 bootstrap token 认证文件

1.6开启 apiserver 服务

​编辑

1.7启动 scheduler 服务

1.8启动 controller-manager 服务

1.9启动admin服务并生成kubectl连接集群的kubeconfig文件

五、部署 Worker Node 组

1.先在node01和node02上创建kubernetes工作目录

2.在 master01 节点上操作

2.1把配置文件 拷贝到 node 节点

3.RBAC授权,使用户 kubelet-bootstrap 能够有权限发起 CSR 请求证书

4.在node01上操作

5.在master01上操作

6.在node01上操作


一、准备环境

1.1 修改主机名

hostnamectl set-hostname master01
su
hostnamectl set-hostname node01
su
hostnamectl set-hostname node02
su

Master01 192.168.21.10
node01 192.168.21.30
node02 192.168.21.40

1.2 关闭防火墙(三台一起,这里只展示master01)

关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
iptables -F && iptables -t nat -F && iptables -t mangle -F && iptables -X
#关闭selinux
setenforce 0
sed -i 's/enforcing/disabled/' /etc/selinux/config
关闭swap
swapoff -a
sed -ri 's/.*swap.*/#&/' /etc/fstab 

1.3 在master添加hosts(依旧是三台一起)

vim /etc/hosts

#添加ip
192.168.21.10 master01
192.168.21.30 node01
192.168.21.40 node02

1.4 调整内核参数并开启网桥模式

#调整内核参数
cat > /etc/sysctl.d/k8s.conf << EOF
#开启网桥模式,可将网桥的流量传递给iptables链
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
#关闭ipv6协议
net.ipv6.conf.all.disable_ipv6=1
net.ipv4.ip_forward=1
EOF
sysctl --system   刷新

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

如果报错是软件版本的问题,或者dns原因这边建议修改dns都为114.114.114.114

二、部署docker引擎

//所有 node 节点部署docker引擎
yum install -y yum-utils device-mapper-persistent-data lvm2 
yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo 
yum install -y docker-ce docker-ce-cli containerd.io

systemctl start docker.service
systemctl enable docker.service 

三、部署 etcd 集群 

etcd是CoreOS团队于2013年6月发起的开源项目,它的目标是构建一个高可用的分布式键值(key-value)数据库。etcd内部采用raft协议作为一致性算法,etcd是go语言编写的。

etcd 作为服务发现系统,有以下的特点
简单:安装配置简单,而且提供了HTTP API进行交互,使用也很简单
安全:支持SSL证书验证
快速:单实例支持每秒2k+读操作
可靠:采用raft算法,实现分布式系统数据的可用性和一致性

etcd 目前默认使用2379端口提供HTTP API服务, 2380端口和peer通信(这两个端口已经被IANA(互联网数字分配机构)官方预留给etcd)。 即etcd默认使用2379端口对外为客户端提供通讯,使用端口2380来进行服务器间内部通讯。
etcd 在生产环境中一般推荐集群方式部署。由于etcd 的leader选举机制,要求至少为3台或以上的奇数台。

1.在master01节点上操作

wget https://pkg.cfssl.org/R1.2/cfssl_linux-amd64 -O /usr/local/bin/cfssl
wget https://pkg.cfssl.org/R1.2/cfssljson_linux-amd64 -O /usr/local/bin/cfssljson
wget https://pkg.cfssl.org/R1.2/cfssl-certinfo_linux-amd64 -O /usr/local/bin/cfssl-certinfo
chmod +x /usr/local/bin/cfssl*

因为事先准备好了 我直接拉入

2.生成Etcd证书

1.创建目录
mkdir /opt/k8s
cd /opt/k8s/

#上传 etcd-cert.sh 和 etcd.sh 到 /opt/k8s/ 目录中
chmod +x etcd-cert.sh etcd.sh

2.创建用于生成CA证书、etcd 服务器证书以及私钥的目录
mkdir /opt/k8s/etcd-cert
mv etcd-cert.sh etcd-cert/
cd /opt/k8s/etcd-cert/
./etcd-cert.sh			#生成CA证书、etcd 服务器证书以及私钥

vim etcd-cert.sh

这边要注意两个问题一个是年份,一个是ip地址

3.拷贝服务端

上传 etcd-v3.4.9-linux-amd64.tar.gz 到 /opt/k8s 目录中,启动etcd服务

cd /opt/k8s/
拉入安装包
tar zxvf etcd-v3.4.9-linux-amd64.tar.gz
cd etcd-v3.4.9-linux-amd64/
#创建用于存放 etcd 配置文件,命令文件,证书的目录
mkdir -p /opt/etcd/{cfg,bin,ssl}
mv etcd etcdctl /opt/etcd/bin/
cp *.pem /opt/etcd/ssl/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值