1、kube-proxy 开启 ipvs 的前置条件

  1. $ modprobe br_netfilter
  2. cat > /etc/sysconfig/modules/ipvs.modules <<EOF
  3. # !/bin/bash
  4. modprobe -- ip_vs
  5. modprobe -- ip_vs_rr
  6. modprobe -- ip_vs_wrr
  7. modprobe -- ip_vs_sh
  8. modprobe -- nf_conntrack_ipv4
  9. EOF
  10. $ chmod 755 /etc/sysconfig/modules/ipvs.modules && bash /etc/sysconfig/modules/ipvs.modules &&
  11. lsmod | grep -e ip_vs -e nf_conntrack_ipv4

2、安装 Docker 软件

  1. $ yum install -y yum-utils device-mapper-persistent-data lvm2
  2. $ yum-config-manager \
  3. --add-repo \
  4. http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
  5. $ yum update -y && yum install -y docker-ce
  6. ## 创建 /etc/docker 目录
  7. $ mkdir /etc/docker
  8. # 配置 daemon.
  9. cat > /etc/docker/daemon.json <<EOF
  10. {
  11. "exec-opts": ["native.cgroupdriver=systemd"],
  12. "log-driver": "json-file",
  13. "log-opts": {
  14. "max-size": "100m"
  15. }
  16. }
  17. EOF
  18. $ mkdir -p /etc/systemd/system/docker.service.d
  19. # 重启docker服务
  20. $ systemctl daemon-reload && systemctl restart docker && systemctl enable docker

3、安装 Kubeadm (主从配置)

  1. cat <<EOF > /etc/yum.repos.d/kubernetes.repo
  2. [kubernetes]
  3. name=Kubernetes
  4. baseurl=http://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
  5. enabled=1
  6. gpgcheck=0
  7. repo_gpgcheck=0
  8. gpgkey=http://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
  9. http://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
  10. EOF
  11. $ yum -y install kubeadm-1.15.1 kubectl-1.15.1 kubelet-1.15.1
  12. $ systemctl enable kubelet.service

kubeadm 初始化工具 kubectl 命令行管理工具 kubelet 和docker CRI交互 创建容器


4、镜像操作

提前导入 k8s 需要的镜像,不然启动时再拉取因网络原因会很慢

  1. $ tar -zxvf kubeadm-basic.images.tar.gz
  2. $ vim load-images.sh

load-images.sh

  1. cat <<EOF > ./load-images.sh
  2. #!/bin/bash
  3. ls /root/kubeadm-basic.images > /tmp/image-list.txt
  4. cd /root/kubeadm-basic.images
  5. for i in $( cat /tmp/image-list.txt )
  6. do
  7. docker load -i $i
  8. done
  9. rm -rf /tmp/image-list.txt
  10. EOF
  1. $ sh ./load-images.sh

文件拷贝到其它节点并执行

  1. $ scp -r kubeadm-basic.images load-images.sh root@k8s-node01:/root/
  2. $ scp -r kubeadm-basic.images load-images.sh root@k8s-node02:/root/

5、初始化主节点

  1. # 获取 kubeadm 默认的配置文件内容打印至 kubeadm-config.yaml
  2. $ kubeadm config print init-defaults > kubeadm-config.yaml

修改 kubeadm-config.yaml 内容:

  1. localAPIEndpoint:
  2. advertiseAddress: 192.168.66.10 # 修改为本机IP
  3. kubernetesVersion: v1.15.1 # 修改为当前的k8s版本
  4. networking:
  5. podSubnet: "10.244.0.0/16" # 指定pod网段
  6. serviceSubnet: 10.96.0.0/12
  7. # 在最后追加,把默认调度方式改为 ipvs 方式
  8. ---
  9. apiVersion: kubeproxy.config.k8s.io/v1alpha1
  10. kind: KubeProxyConfiguration
  11. featureGates:
  12. SupportIPVSProxyMode: true
  13. mode: ipvs
  1. $ kubeadm init --config=kubeadm-config.yaml --experimental-upload-certs | tee kubeadm-init.log

PS: kubeadm-config.yaml 配置文件 kubeadm-init.log 输出日志 /etc/kubernetes/pki 证书目录

6、加入主节点以及其余工作节点

image.png

  1. # 执行安装日志中的加入命令即可
  2. $ mkdir -p $HOME/.kube
  3. $ sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
  4. $ sudo chown $(id -u):$(id -g) $HOME/.kube/config

7、部署网络

  1. $ mkdir -p install-k8s/core/ install-k8s/plugin/flannel/
  2. # 备份
  3. $ mv kubeadm-init.log kubeadm-config.yaml install-k8s/core/
  4. [root@k8s-master01 flannel]
  5. # 下载 flannel 配置文件
  6. $ wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
  7. # 按照配置文件安装 flannel
  8. $ kubectl create -f kube-flannel.yml
  9. # 查看 flannel 组件运行状态
  10. $ kubectl get pod -n kube-system

查看状态结果
image.png
启动失败原因

k8s在使用编排(manifest)工具进行yaml文件启动pod时,会遇到官方所给例子中spec.containers.image包含:


  1. quay.io/coreos/example_
  2. gcr.io/google_containers/example_

也就是说,从quay.io和gcr.io进行镜像拉取,国内访问外网是被屏蔽了的,需要替换镜像源。 例如: 下拉镜像:quay.io/coreos/flannel:v0.10.0-s390x 如果拉取较慢,可以改为:quay-mirror.qiniu.com/coreos/flannel:v0.10.0-s390x 下拉镜像:gcr.io/google_containers/kube-proxy 可以改为: registry.aliyuncs.com/google_containers/kube-proxy

解决:替换 kube-flannel.yml 中所有 quay.io 为 quay-mirror.qiniu.com

  1. [root@k8s-master01 flannel]$
  2. $ vim kube-flannel.yml
  3. # 全局替换操作
  4. %s/quay.io/quay-mirror.qiniu.com/g
  5. $ kubectl apply -f kube-flannel.yml

image.png


将其它节点加入
image.png

  1. [root@k8s-node01 ~]$
  2. kubeadm join 192.168.5.80:6443 --token abcdef.0123456789abcdef \
  3. --discovery-token-ca-cert-hash sha256:a9d3e7ec54046e863832fff64549915d46574ce943681dd33a9be00da481300b
  4. [root@k8s-node02 ~]$
  5. kubeadm join 192.168.5.80:6443 --token abcdef.0123456789abcdef \
  6. --discovery-token-ca-cert-hash sha256:a9d3e7ec54046e863832fff64549915d46574ce943681dd33a9be00da481300b

image.png
image.png