centos7系统部署k8s集群详细介绍

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

centos7系统部署k8s集群详细介绍⽬录
1 版本、规划
1.1 版本信息:
1.2集群规划
2.部署
1、关闭防⽕墙
2、关闭selinux
3、关闭swap
4、添加主机名和IP对应关系
5、将桥接的IPV4流量传递给iptables的链
6、安装docker 安装:
7、添加阿⾥云yum软件源
8、安装kubeadm、kubelet、kubectl
9、初始化master节点
10、安装pod⽹络插件(CNI)
11、node节点加⼊集群
1 版本、规划
1.1 版本信息:
名称版本号
内核 3.10.0-1160.el7.x86_64
操作系统CentOS Linux release 7.9.2009 (Core)
docker20.10.11
kubeadm1.23.0
kubelet 1.23.0
kubectl 1.23.0
1.2集群规划
IP hostname
192.168.0.114k8s-master
192.168.0.115k8s-node01
192.168.0.116k8s-node02
2.部署
说明:
第1步~第8步,所有节点都要操作master节点:第9、10步node节点:第11步
1、关闭防⽕墙
关闭:systemctl stop firewalld
永久关闭:systemctl disable firewalld
2、关闭selinux
关闭:setenforce 0
3、关闭swap
临时关闭:swapoff -a
永久关闭:sed -ri 's/.*swap.*/#&/' /etc/fstab,通过该命令注释掉含swap⾏的代码
检验:free -m
4、添加主机名和IP对应关系
根据1.2中规划内容在/etc/hosts中添加映射关系
192.168.0.114 k8s-master
192.168.0.115 k8s-node01
192.168.0.116 k8s-node02
5、将桥接的IPV4流量传递给iptables的链
使⽤以下命令添加配置:
cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
执⾏sysctl --system命令使配置⽣效:
6、安装docker 安装:
wget https:///docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
yum install docker-ce
设置开机⾃启
systemctl start docker
systemctl enable docker
查看版本:docker version可能遇到的坑(此处暂且跳过,后⾯遇到可回来修改):
问题:使⽤命令docker info|grep cgroup查看,如果docker使⽤的Cgroup Driver为cgroupfs。

则有可能跟kubelet冲突,需要改为⼀致的systemd
解决⽅法1:vi /etc/docker/daemon.json,在⽂件中添加如下代码,重启docker即可
{
"exec-opts": ["native.cgroupdriver=systemd"]
}
解决⽅法2:也可以修改docker启动服务中的ExecStart,添加参数"--exec-opt native.cgroupdriver=systemd"
# docker.service
vi /usr/lib/systemd/system/docker.service
# 添加
ExecStart=/usr/bin/dockerd --exec-opt native.cgroupdriver=systemd
7、添加阿⾥云yum软件源
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https:///kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https:///kubernetes/yum/doc/yum-key.gpg
https:///kubernetes/yum/doc/rpm-package-key.gpg
EOF
可能遇到的坑(此处暂且跳过,后⾯遇到可回来操作)
问题:安装过程中,可能提⽰xxx.rpm 公钥尚未安装
解决⽅法1:导⼊公钥后,再次重装即可
wget https:///kubernetes/yum/doc/yum-key.gpg
wget https:///kubernetes/yum/doc/rpm-package-key.gpg
rpm --import yum-key.gpg
rpm --import rpm-package-key.gpg
解决⽅法2:kubernetes.repo⽂件中配置gpgchekc为0,不检查即可
8、安装kubeadm、kubelet、kubectl
安装:yum install -y kubelet-1.23.0 kubectl-1.23.0 kubeadm-1.23.0
或者安装最新也⾏:yum install -y kubelet kubectl kubeadm
设置开启⾃启:systemctl enable kubelet,此处只需设置开机启动即可。

因为配置还未成,不必启动,启动也会不成功
9、初始化master节点
初始化命令
kubeadm init \
--image-repository /google_containers \
--kubernetes-version v1.23.0 \
--service-cidr=10.1.0.0/16 \
--pod-network-cidr=10.244.0.0/16
参数说明
--image-repository string Choose a container registry to pull control plane images from (default “k8s.gcr.io”)此处使⽤阿⾥云的registry,否则会很慢,甚⾄失败若安装失败,需要先⽤kubeadm reset命令清理下环境,再重装。

遇到的坑:
初始化成功如果出现以下结果,表⽰初始化成功
根据提⽰,执⾏以下命令
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
# 第1条命令:表⽰创建隐藏⽂件夹.kube
# 第2条命令:表⽰复制⽂件admin.conf到该⽂件夹下
# 第3条命令:表⽰设置⽂件的所属⽤户、⽤户组
执⾏完以上命令即可使⽤kubectl命令,否则会提⽰The connection to the server localhost:8080 was refused - did you specify the right host or port?
10、安装pod⽹络插件(CNI)
安装插件:
kubectl apply -f https:///coreos/flannel/master/Documentation/kube-flannel.yml 遇到的坑
查看是否部署成功:kubectl get pods -n kube-system
再次查看节点,状态变为ready
11、node节点加⼊集群
向集群添加新节点,只需要将master节点中执⾏kubeadm init成功后的kubeadm join命令复制到要添加的node节点中执⾏即可
kubeadm join 192.168.0.114:6443 --token whxbm2.x70y9k1feop2604b \
--discovery-token-ca-cert-hash sha256:d4306836b7ef32fd802e559cf717bbbe3af6dd75d3cb2fa4d3db7a16cc25a657
成功加⼊后,通过master节点使⽤命令kubectl get nodes,即可发现node节点已加⼊到集群中,并且状态为ready(此处要稍等⼀会)
到此这篇关于centos7系统部署k8s集群详细介绍的⽂章就介绍到这了,更多相关centos7部署k8s集群内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!。

相关文档
最新文档