centos离线安装docker和K8S集群
centos离线安装docker和K8S集群
centos离线安装docker和K8S集群
1、背景及概述
1.1、背景
当在生产环境或者公司网络覆盖环境中想要安装DOCKER和K8S时,受限于网络的原因,常常需要离线安装。
1.2、概述
基本上K8S的安装分为两种方式,二进制安装和kubeadm安装。Kubeadm是一个K8s部署工具,提供kubeadm init和kubeadm join,用于快速部署Kubernetes集群。本文档基于kubeadm安装的方式,进行改进,缩减安装步骤。
2、环境准备
操作系统 IP CPU/MEM 主机名 角色
CentOS 7.7-x86_64 10.0.0.158 2/4G k8s-master master
CentOS 7.7-x86_64 10.0.0.157 2/4G k8s-node111 work node1
CentOS 7.7-x86_64 10.0.0.159 2/4G k8s-node222 work node2
【版本号】
name version
Docker 19.03.12
kubeadm 1.21.2
kubernetes 1.21.2
3、安装配置Centos环境
1)安装centos(省略)
该步骤可以参考网上虚拟机安装centos的步骤。
2)打开网口
默认centos的网络是没开的,所以安装好系统之后打开网口
3.1、安装centos(省略)
该步骤可以参考网上虚拟机安装centos的步骤。
3.2、打开网口
默认centos的网络是没开的,所以安装好系统之后打开网口,进行SSH连接,方便后续传输文件。但是由于还不知道系统的ip所以需要先查询ip。
1)配置yum源
配置centos的代理,yum的配置文件在/etc/yum.conf上。
2)下载ip查询工具
$ yum install net-tools
$ ifconfig
3)打开网口
默认centos是不打开网口的,所以需要手动打开,配置文件是/etc/sysconfig/network-scripts/ifcfg-ens33,把ONBOOT改为yes。
4)SSH连接
现在可以进行SSH连接了,连接后将附件k8s-install复制到系统里。
4、安装部署
4.1、部署master节点
1)一键部署
本文档提供一键式的部署脚本进行安装部署。
$ chmod +x install.sh
$ ./install.sh k8s-master
2)结果验证
当出现下列提示证明安装成功。
$ hostname
该操作会升级系统内核,重启前内核
重启后内核
$ uname -r
3)使用 kubeadm 初始化集群
$ kubeadm init --kubernetes-version=v1.21.2 --apiserver-advertise-address=10.0.0.158 --pod-network-cidr=10.244.0.0/16 --service-cidr=10.96.0.0/12
其中,
–apiserver-advertise-address 集群通告地址,改为自己的
–image-repository 由于默认拉取镜像地址k8s.gcr.io国内无法访问,这里指定阿里云镜像仓库地址
–kubernetes-version K8s版本,与上面安装的一致
–service-cidr 集群内部虚拟网络,Pod统一访问入口
–pod-network-cidr Pod网络,与下面部署的CNI网络组件yaml中保持一致
初始化之后,会输出一个join命令,先复制出来,node节点加入master会使用。
4)执行提示命令
$ mkdir -p $HOME/.kube
$ sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
$ sudo chown
(
i
d
−
u
)
:
(id -u):
(id−u):(id -g) $HOME/.kube/config
初始化完成后,执行提示命令,将join命令记录下来,这是将node节点加入到集群的执行操作命令。
kubeadm join 10.0.0.158:6443 --token gauycz.ct40nhvbonr0h34i --discovery-token-ca-cert-hash sha256:55d7b2468e2808abce7fd52f578aca3509a50ff1d051dd5cd78c2d4637c75985
5)使用 kubectl 查看 nodes
当前状态Notready,是因为网络插件flannel还没有部署。
4.2、初始化网络插件 flannel
1)加载镜像(所有节点都加载)
$ docker load < flannel-v0.14.0.tar
2)初始化(只在master)
$ kubectl apply -f kube-flannel-v0.14.1.yml
3)使用 kubectl 查看 nodes
$ kubectl get nodes
至此,master操作完成。
4.3、部署node节点
1)部署node111
步骤和部署master部署一样,只是运行脚本时,设置成当前的节点名。
$ ./install.sh k8s-node111
2)加入集群
执行master步骤初始化集群后记录的命令,如下:
kubeadm join 10.0.0.158:6443 --token gauycz.ct40nhvbonr0h34i --discovery-token-ca-cert-hash sha256:55d7b2468e2808abce7fd52f578aca3509a50ff1d051dd5cd78c2d4637c75985
3)验证
去master查看集群节点信息,如果STATUS状态为NotReady,如下图,就多等一会,可能是加入未完成。
4)复制admin.conf文件
使用scp命令将maser的“/etc/kubernetes/admin.conf”复制到node节点
k8s-master执行:
$ scp /etc/kubernetes/admin.conf root@10.0.0.159:/etc/kubernetes/
k8s-node111执行:
$ echo “export KUBECONFIG=/etc/kubernetes/admin.conf” >> ~/.bash_profile
$ source ~/.bash_profile
现在可以在k8s-node111节点使用kubectl命令了
同理加入node222节点方法也一样。
本文重点参考:https://www.cnblogs.com/nbzws/p/15675596.html
更多推荐
所有评论(0)