Ubuntu 16.04使用kubeadm方式部署k8s 1.18.3

这里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

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,以下是使用kubeadm部署Kubernetes 1.27.4的步骤: 1. 确认k8s版本和环境:首先,确认您要部署Kubernetes版本为1.27.4,并确保您的环境满足部署要求,例如操作系统版本、CPU和内存等。 2. 创建配置文件:根据您的需求,创建Kubernetes集群的配置文件,包括证书、网络插件、镜像源等。您可以根据实际情况进行配置。 3. 安装kubeadm:在两台Ubuntu 16.04 64位双核CPU虚拟机上安装kubeadm。您可以使用以下命令安装kubeadm: ```shell sudo apt-get update sudo apt-get install -y kubeadm ``` 4. 初始化Master节点:在其中一台虚拟机上执行以下命令初始化Master节点: ```shell sudo kubeadm init --kubernetes-version=1.27.4 ``` 该命令将会初始化Kubernetes Master节点,并生成一个加入集群的命令。 5. 部署网络插件:根据您的配置文件选择网络插件,这里以flannel为例。在Master节点上执行以下命令部署flannel网络插件: ```shell kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml ``` 6. 加入Worker节点:在另一台虚拟机上执行Master节点生成的加入集群的命令,将其加入到Kubernetes集群中: ```shell sudo kubeadm join <Master节点IP>:<Master节点端口> --token <Token值> --discovery-token-ca-cert-hash <证书哈希值> ``` 请将`<Master节点IP>`、`<Master节点端口>`、`<Token值>`和`<证书哈希值>`替换为实际的值。 至此,您已成功使用kubeadm部署Kubernetes 1.27.4集群。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值