1. PD安装2个Centos7.6 1816虚拟机(例如主机名cc和主机名cc2), 或2台云主机, 或VM安装虚拟机(建议使用主机同一网络).请勿使用克隆, 克隆的虚拟与原虚拟机product_uuid一致.

安装或启动过程中容易碰到问题, 日志排查图放在前面官方安装地址

排查

2. 安装前检查

  1. hostname必须不一致
hostname
  1. 网络互通, 互ping

  2. mac ip地址不一致

ifconfig
  1. product_uuid不一致
cat /sys/class/dmi/id/product_uuid
  1. 禁用Swap交换分区, 保证kubelet正确运行, 必须永久禁用. 在安装设置中有对应的设置.

3. 安装前2台虚拟机都需要的设置

  1. 安装指定版本的docker.

# 移除旧版本docker
yum remove docker \
              docker-common \
              docker-selinux \
              docker-engine

# 安装工具
yum install -y yum-utils \
device-mapper-persistent-data \
  lvm2


# 安装指定版本containerd.io
yum install https://download.docker.com/linux/centos/7/x86_64/stable/Packages/containerd.io-1.2.6-3.3.el7.x86_64.rpm


# 下载设置源
yum-config-manager \
    --add-repo \
    https://download.docker.com/linux/centos/docker-ce.repo


# 查看全部版本的docker.
yum list docker-ce --showduplicates | sort -r

# kubernetes支持最高18.09
yum install docker-ce-18.09.9-3.el7

# 如yum失败, 使用dnf
dnf install docker-ce-18.09.9-3.el7

# 设置开机启动docker, 启动docker

systemctl enable docker
systemctl start docker
  1. 关闭防火墙, 不关闭集群间有些pod可能无法通信.
systemctl stop firewalld

# 禁止开机启动
systemctl disable firewalld
  1. 永久禁用交换分区swap.
# vi /etc/fstab
注释最后一行的swap

# 可在操作步骤3后一起重启.
reboot
  1. 装SELinux设置permissive模式
sed -i 's/^SELINUX=enforcing$/SELINUX=permissive/' /etc/selinux/config

# 重启
reboot
  1. 安装源

# 国内
cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
EOF


# 国外主机
cat <<EOF > /etc/yum.repos.d/kubernetes.repo
[kubernetes]
name=Kubernetes
baseurl=https://packages.cloud.google.com/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=1
repo_gpgcheck=1
gpgkey=https://packages.cloud.google.com/yum/doc/yum-key.gpg https://packages.cloud.google.com/yum/doc/rpm-package-key.gpg
exclude=kube*
EOF
  1. 解决国内缺少镜像问题
# 第一种方式, 脚本获取镜像并重命名
vim images.sh

#!/bin/bash
images=(
    kube-apiserver:v1.15.6
    kube-controller-manager:v1.15.6
    kube-scheduler:v1.15.6
    kube-proxy:v1.15.6
    pause:3.1
    etcd:3.3.10
    coredns:1.3.1

)

for imageName in ${images[@]} ; do
    docker pull registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName
    docker tag registry.cn-hangzhou.aliyuncs.com/google_containers/$imageName k8s.gcr.io/$imageName
done



# 第二种方式, 搜索下载, 并重命名


# 查看必需镜像
kubeadm config images list

# 下载必需镜像
kubeadm config images pull

# 下载不了的images, 搜索到, 下载, 重命名就行

docker search 
docker pull
docker tag 

docker pull mirrorgooglecontainers/kube-apiserver:v1.14.2
docker pull mirrorgooglecontainers/kube-controller-manager:v1.14.2
docker pull mirrorgooglecontainers/kube-scheduler:v1.14.2
docker pull mirrorgooglecontainers/kube-proxy:v1.14.2
docker pull mirrorgooglecontainers/pause:3.1
docker pull mirrorgooglecontainers/etcd:3.3.10
docker pull coredns/coredns:1.3.1

docker tag mirrorgooglecontainers/kube-controller-manager:v1.14.2 k8s.gcr.io/kube-controller-manager:v1.14.2
docker tag mirrorgooglecontainers/kube-scheduler:v1.14.2  k8s.gcr.io/kube-scheduler:v1.14.2
docker tag mirrorgooglecontainers/kube-apiserver:v1.14.2 k8s.gcr.io/kube-apiserver:v1.14.2
docker tag mirrorgooglecontainers/kube-proxy:v1.14.2 k8s.gcr.io/kube-proxy:v1.14.2
docker tag mirrorgooglecontainers/pause:3.1 k8s.gcr.io/pause:3.1
docker tag mirrorgooglecontainers/etcd:3.3.10 k8s.gcr.io/etcd:3.3.10
docker tag coredns/coredns:1.3.1 k8s.gcr.io/coredns:1.3.1
  1. 解决网络错误

cat <<EOF >  /etc/sysctl.d/k8s.conf
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
net.ipv4.ip_forward = 1
EOF
sysctl --system
modprobe br_netfilter
  1. 设置推荐的systemd driver
# Setup daemon.
cat > /etc/docker/daemon.json <<EOF
{
  "exec-opts": ["native.cgroupdriver=systemd"],
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "100m"
  },
  "storage-driver": "overlay2",
  "storage-opts": [
    "overlay2.override_kernel_check=true"
  ]
}
EOF

mkdir -p /etc/systemd/system/docker.service.d

# Restart Docker
systemctl daemon-reload
systemctl restart docker

4. 主master和从node需要开放的端口, 防火墙可以打开, 执行完毕后再关闭. 80,443个人补充的, 官方中并没有.

1. 在主节点上写入hosts内容

# 在一台机器上, 添加ip和主机名到/etc/hosts中

10.211.55.5 cc
10.211.55.6 cc2

2. Master节点需要开放的端口, 例如cc主机中

systemctl start firewalld

firewall-cmd --zone=public --add-port=6443/tcp --permanent

firewall-cmd --zone=public --add-port=2379-2380/tcp --permanent

firewall-cmd --zone=public --add-port=10250/tcp --permanent

firewall-cmd --zone=public --add-port=10251/tcp --permanent

firewall-cmd --zone=public --add-port=10252/tcp --permanent

firewall-cmd --zone=public --add-port=80/tcp --permanent

firewall-cmd --zone=public --add-port=443/tcp --permanent

firewall-cmd --reload

systemctl stop firewalld

3. Node节点需要开放的端口, 如cc2主机.

systemctl start firewalld

firewall-cmd --zone=public --add-port=10250/tcp --permanent

firewall-cmd --zone=public --add-port=10254/tcp --permanent

firewall-cmd --zone=public --add-port=30000-32767/tcp --permanent


firewall-cmd --zone=public --add-port=80/tcp --permanent


firewall-cmd --zone=public --add-port=443/tcp --permanent

firewall-cmd --reload

systemctl stop firewalld

5. 开始安装Kubernetes


# 查看所有可安装的k8s版本

yum list --showduplicates kubeadm --disableexcludes=kubernetes

yum install -y kubelet-1.15.6 kubeadm-1.15.6  kubectl-1.15.6 --disableexcludes=kubernetes


# 设置开机启动
systemctl enable kubelet && systemctl start kubelet

6. 主机master上执行初始化.



kubeadm init --pod-network-cidr=10.244.0.0/16 --apiserver-advertise-address=<服务器ip>

7. 对用户的设置, 如果想cc或cc2中任何用户(root或者普通用户)可操作kubectl, 需要装.kube文件移动到对应的用户下.

mkdir -p $HOME/.kube
cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
chown $(id -u):$(id -g) $HOME/.kube/config

8. 查看是否初完成, 解决coredns pending问题

# 检查主机是否准备完成

kubectl get nodes
# 会显示not ready, 安装下面的网络插件即可解决

# 查看系统pod是否初始化完成
kubectl get pods -n kube-system

9. corednse显示pending中, 解决安装网络插件, 安装完毕等待几分钟即可.

curl -O https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

kubectl apply -f kube-flannel.yml

kubectl apply -f "https://cloud.weave.works/k8s/net?k8s-version=$(kubectl version | base64 | tr -d '\n')"

10. 添加node, 在node节点执行, 初始化完会显示在列表中

添加节点时确认执行第9步的网络插件安装

kubeadm join 10.211.55.5:6443 --token ylml1p.xhp333geob6tvtkh \
--discovery-token-ca-cert-hash sha256:e5541130096be094

11. 出现错误, 通过日志排查问题.

排查

12. 补充错误

The connection to the server localhost:8080 was refused - did you specify the right host or port?

则需要执行第7条内容.

解决 /proc/sys/net/bridge/bridge-nf-call-iptables contents are not set to 1
echo '1' > /proc/sys/net/bridge/bridge-nf-call-iptables

13. 重置节点

kubeadm reset

rm -rf $HOME/.kube/
rm -rf /var/lib/cni/
rm -rf /var/lib/kubelet/*
rm -rf /etc/cni/
ip link delete cni0
ip link delete flannel.1
systemctl restart docker

14. kubernetes命令

# kubernetes将pod调度到master节点

kubectl taint node <主机节点名称> node-role.kubernetes.io/master-
kubectl taint node mm.com node-role.kubernetes.io/master-

# 恢复Master Only状态

kubectl taint node <主机节点名称> node-role.kubernetes.io/master=""

# 立即删除一个pod
kubectl delete pods <pod> --grace-period=0 --force