一、系统初始化
1. 关闭防火墙
systemctl stop firewalld && systemctl disable firewalld
2. 关闭selinux
setenforce 0
3. 关闭swap分区
swapoff -a # 临时关闭
4. 将桥接的 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配置
sysctl --system
二、安装docker
1. 配置yum源(阿里源)
wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
2. 安装docker
yum -y install docker-ce-18.06.1.ce-3.el7
3. 启动docker
systemctl enable docker && systemctl start docker # 启动并设置开机启动
三、安装kubernetes
1. 配置k8s的yum源
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
2. 安装kubeadm、kubelet、kubectl
yum install -y kubelet-1.16.3 kubeadm-1.16.3 kubectl-1.16.3
3. 初始化kubeadm
kubeadm init \
--apiserver-advertise-address=192.168.149.144 \
--image-repository registry.aliyuncs.com/google_containers \
--kubernetes-version v1.16.3 \
--service-cidr=10.96.0.0/12 \
--pod-network-cidr=10.244.0.0/16
其中
—apiserver-advertise-address 集群通告地址(可以直接设置为本机IP)
—image-repository 由于默认拉取镜像地址k8s.gcr.io国内无法访问,这里指定阿里云镜像仓库地址。
—kubernetes-version K8s版本,与上面安装的一致
—service-cidr 集群内部虚拟网络,Pod统一访问入口
—pod-network-cidr Pod网络,与下面部署的CNI网络组件yaml中保持一致
然后由初始化kubeadm时的提示依次执行
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
如果要部署集群,可以将初始化生成的加入集群命令保存下来,格式为
kubeadm join your_ip:port --token token_value --discovery-token-ca-cert-hash sha256:hash_value
启动kubelet
systemctl enable kubelet && systemctl start kubelet # 启动并设置开机启动
4. 安装网络插件
# 下载
wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
# 执行
kubectl apply -f kube-flannel.yml
执行结果如下
如上图所以,即执行成功
5. 查看节点
查看节点状态
kubectl get nodes
查看pod状态
kubectl get pod -n kube-system
如上所示,master节点状态为Ready,pod状态为Running,这说明已成功
如果安装过程中出现问题,可清理环境重新安装
kubeadm reset
另:
# 删除 flannel
kubectl delete -f kube-flannel.yml
转载自:https://www.cnblogs.com/quanloveshui/p/13518664.html