kubeadm 安裝 kubernetes1.9.1

參考網址:https://kubernetes.io/docs/setup/independent/install-kubeadm/
https://kubernetes.io/docs/setup/independent/create-cluster-kubeadm/

安裝docker

centos7安裝docker二進制包
https://download.docker.com/linux/centos/7/x86_64/stable/Packages/下載docker rpm包
我下載了docker-ce-17.03.2.ce-1.el7.centos.x86_64.rpm 和 docker-ce-selinux-17.03.2.ce-1.el7.centos.noarch.rpm
執行命令

yum localinstall docker-ce-selinux-17.03.2.ce-1.el7.centos.noarch.rpm docker-ce-17.03.2.ce-1.el7.centos.x86_64.rpm

安裝kubeadm

1、安裝cni插件

CNI_VERSION="v0.6.0"
mkdir -p /opt/cni/bin
curl -L "https://github.com/containernetworking/plugins/releases/download/${CNI_VERSION}/cni-plugins-amd64-${CNI_VERSION}.tgz" | tar -C /opt/cni/bin -xz

2、安裝kubeadm kubelet kubectl

RELEASE="$(curl -sSL https://dl.k8s.io/release/stable.txt)"

mkdir -p /opt/bin
cd /opt/bin
curl -L --remote-name-all https://storage.googleapis.com/kubernetes-release/release/${RELEASE}/bin/linux/amd64/{kubeadm,kubelet,kubectl}
chmod +x {kubeadm,kubelet,kubectl}

curl -sSL "https://raw.githubusercontent.com/kubernetes/kubernetes/${RELEASE}/build/debs/kubelet.service" | sed "s:/usr/bin:/opt/bin:g" > /etc/systemd/system/kubelet.service
mkdir -p /etc/systemd/system/kubelet.service.d
curl -sSL "https://raw.githubusercontent.com/kubernetes/kubernetes/${RELEASE}/build/debs/10-kubeadm.conf" | sed "s:/usr/bin:/opt/bin:g" > /etc/systemd/system/kubelet.service.d/10-kubeadm.conf

設置開機啓動並啓動kubelet

systemctl enable kubelet && systemctl start kubelet

kubeadm安裝k8s

下載k8s的docker 鏡像
k8s1.9.x版本所需的docker鏡像在https://kubernetes.io/docs/reference/setup-tools/kubeadm/kubeadm-init/ 有說明。
k8s

#!/bin/bash

set -x
dockerimages=(k8s.gcr.io/kube-apiserver-amd64:v1.9.1
k8s.gcr.io/kube-controller-manager-amd64:v1.9.1
k8s.gcr.io/kube-scheduler-amd64:v1.9.1
k8s.gcr.io/kube-proxy-amd64:v1.9.1
k8s.gcr.io/etcd-amd64:3.1.10
k8s.gcr.io/pause-amd64:3.0
k8s.gcr.io/k8s-dns-sidecar-amd64:1.14.7
k8s.gcr.io/k8s-dns-kube-dns-amd64:1.14.7
k8s.gcr.io/k8s-dns-dnsmasq-nanny-amd64:1.14.7)

j=1
for i in ${dockerimages[@]}
do
    echo $i
    echo $j

    docker pull $i && docker save $i | xz $j.tar.xz
    docker rmi $i
    let j+=1
done
set +x

1、初始化master
配置主機的192.168.122.120爲apiserver監聽的地址,設置pod的網段爲10.244.0.0/16

kubeadm init --apiserver-advertise-address=192.168.122.120  --pod-network-cidr=10.244.0.0/16 --kubernetes-version=v1.9.1 --ignore-preflight-errors=Swap

2、配置非root用戶使用kubectl命令

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

root用戶使用kubectl命令

export KUBECONFIG=/etc/kubernetes/admin.conf

3、安裝pod網絡
這裏我使用canal網絡插件

kubectl apply -f https://raw.githubusercontent.com/projectcalico/canal/master/k8s-install/1.7/rbac.yaml
kubectl apply -f https://raw.githubusercontent.com/projectcalico/canal/master/k8s-install/1.7/canal.yaml

4、配置master可以調度並運行pod

kubectl taint nodes --all node-role.kubernetes.io/master-

5、加入節點
登錄需要加入的節點機器上,以root運行kubeadm init運行後提示的命令

kubeadm join --token <token> <master-ip>:<master-port> --discovery-token-ca-cert-hash sha256:<hash>

kubeadm重置k8s

首先把所有k8s節點設爲維護狀態

kubectl drain <node name> --delete-local-data --force --ignore-daemonsets
kubectl delete node <node name>

執行reset命令

kubeadm reset
ifconfig cni0 down
ip link delete cni0
ifconfig flannel.1 down
ip link delete flannel.1
rm -rf /var/lib/cni/

遇到的問題

遇到問題首先查看kubelet程序

systemctl status kubelet
journalctl -xeu kubelet

錯誤提示1

kubelet cgroup driver: "cgroupfs" is different from docker cgroup driver: "systemd"

編輯kubelet的配置文件/etc/systemd/system/kubelet.service.d/10-kubeadm.conf
把–cgroup-driver=cgroupfs替換爲–cgroup-driver=systemd
錯誤提示2

error: failed to run Kubelet: Running with swap on is not supported, please disable swap! or set --fail-swap-on flag to false

編輯kubelet的配置文件/etc/systemd/system/kubelet.service.d/10-kubeadm.conf
在–cgroup-driver=systemd加上配置變爲–cgroup-driver=systemd –fail-swap-on=false

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章