Ubuntu 16.04使用kubeadm方式部署k8s 1.18.3
这里kubeadm、 kubectl、 kubelete的版本与k8s版本无关只要在master初始化时指定k8s版本即可关闭防火墙ufw disableufw status#Status: inactive(不活跃)修改主机名hostnamectl set-hostname 主机名su #切换相互解析/etc/hosts免密登录所有机器操作ssh-keygen #一路回车ssh-copy-id关
·
这里kubeadm、 kubectl、 kubelete的版本与k8s版本无关只要在master初始化时指定k8s版本即可
关闭防火墙
ufw disable
ufw status
#Status: inactive(不活跃)
修改主机名
hostnamectl set-hostname 主机名
su #切换
相互解析
/etc/hosts
免密登录
所有机器操作
ssh-keygen #一路回车
ssh-copy-id
关闭swap分区
#临时 立即生效 重启失效
swapoff -a
#永久 重启才生效
将/etc/fastab中的swap一行注释
开启路由转发
vim /etc/sysctl.conf
net.ipv4.ip_forward = 1 #添加
sysctl -p
修改iptables参数
tee /etc/sysctl.d/k8s.conf <<-'EOF'
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
sysctl --system #重新加载
卸载旧docker
apt-get remove docker docker-engine docker.io
安装依赖
apt-get update #更新apt源
apt-get install \
apt-transport-https \
ca-certificates \
curl \
software-properties-common
添加docker的GPG key ##阿里云
curl -fsSL https://mirrors.aliyun.com/docker-ce/linux/ubuntu/gpg | sudo apt-key add -
配置阿里云apt docker源
add-apt-repository \
"deb [arch=amd64] https://mirrors.aliyun.com/docker-ce/linux/ubuntu \
$(lsb_release -cs) \
stable"
安装docker-ce
apt-get update
apt-get install -y docker-ce
启动docker
systemctl enable docker && sudo systemctl start docker
安装kubeadm、kubelete、kubectl
apt-get update && apt-get install -y apt-transport-https
curl https://mirrors.aliyun.com/kubernetes/apt/doc/apt-key.gpg | apt-key add -
cat <<EOF >/etc/apt/sources.list.d/kubernetes.list
deb https://mirrors.aliyun.com/kubernetes/apt/ kubernetes-xenial main
EOF
apt-get update
apt-get install -y kubelet kubeadm kubectl
启动
systemctl enable kubelet && systemctl start kubelet
master节点初始化,如果初始化出错执行 kubeadm reset 重置节点 再次执行初始化即可
kubeadm init --image-repository registry.aliyuncs.com/google_containers --kubernetes-version v1.18.3 --pod-network-cidr=10.244.0.0/16
#指定k8s版本为1.18.3
###将最后输出的kubeadm join 192.168.1.175:6443 --token v1nj22.l30dctzysf2jynly --discovery-token-ca-cert-hash sha256:0170607e7e069ffde2f2b6b440e7982f066887e59db49e9a62ac9518924af690 保留,在加入节点时执行
如果token忘记,执行kubeadm token create --print-join-command即可
创建kubectl使用的kubeconfig文件
mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown $(id -u):$(id -g) $HOME/.kube/config
添加节点,在所有节点执行
kubeadm join 192.168.1.175:6443 --token v1nj22.l30dctzysf2jynly --discovery-token-ca-cert-hash sha256:0170607e7e069ffde2f2b6b440e7982f066887e59db49e9a62ac9518924af690
部署flannel插件
wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
#注意yml文件中的地址要与初始化地址段对应
kubectl apply -f kube-flannel.yml
#这里会花很长时间下载flannel 镜像,pod会长时间处于init初始化状态,有时节点会下载不下来,可以将master上的镜像打包到节点
docker save -o 包名 镜像
docker load < 包名
部署完成
kubectl get nodes#查看节点状态
所有节点处于Ready状态即部署成功
kubectl get pod -n kube-system #查看各组件状态
所有pod处于running状态既成功
原文更加详细,但有出入原文连接:https://blog.csdn.net/longlong6682/article/details/107147405
更多推荐
已为社区贡献4条内容
所有评论(0)