kubeadm是官方社区推出的一个用于快速部署kubernetes集群的工具。
这个工具能通过两条指令完成一个kubernetes集群的部署:

# kubeadm init                       #创建一个 Master 节点
# kubeadm join <Master节点的IP和端口>  #将一个Node节点加入到当前集群中

服务器要求

• 一台或多台机器,操作系统 CentOS7.x-86_x64
• 硬件配置:2GB或更多RAM,2个CPU或更多CPU,硬盘30GB或更多
• 集群中所有机器之间网络互通
• 可以访问外网,需要拉取镜像
• 禁止swap分区

1、环境准备(所有服务器操作)

1.1、服务器信息及角色:
192.168.6.115   master节点
192.168.6.116   node节点
192.168.6.117   node节点

1.2、关闭防火墙:
# systemctl stop firewalld
# systemctl disable firewalld

1.3、关闭selinux:
# sed -i 's/enforcing/disabled/' /etc/selinux/config

1.4、关闭swap:
# swapoff -a

1.5、添加主机名与IP对应关系:
# cat /etc/hosts
192.168.6.115 ks-115
192.168.6.116 ks-116
192.168.6.117 ks-117

1.6、将桥接的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 --system

2、安装docker/kubeadm/kubelet(所有服务器操作)

2.1、安装Docker:
# wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repos.d/docker-ce.repo
# yum -y install docker-ce
# systemctl start docker
# systemctl enable docker
# docker --version

2.2、添加阿里云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=1
repo_gpgcheck=1
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF

2.3、安装kubeadm,kubelet和kubectl:
# yum -y install kubelet-1.14.0
# yum -y install kubeadm-1.14.0 kubectl-1.14.0
# systemctl start kubelet && systemctl enable kubelet
# rpm -qa|grep kube

3、部署Kubernetes Master(master端操作)

# kubeadm init \
  --apiserver-advertise-address=192.168.6.115 \
  --image-repository registry.aliyuncs.com/google_containers \
  --kubernetes-version v1.14.0 \
  --service-cidr=10.1.0.0/16 \
  --pod-network-cidr=10.244.0.0/16

注:下面截图中框出来的内容后面会用到

4、使用kubectl工具(master端操作)

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

5、安装Pod网络插件(CNI,master端操作)

# wget https://raw.githubusercontent.com/coreos/flannel/a70459be0084506e4ec919aa1c114638878db11b/Documentation/kube-flannel.yml
# kubectl apply -f kube-flannel.yml

注:kube-flannel.yml 文件中的镜像地址原本是国外的,访问不了可以改成个人镜像地址:liyupei/flannel:v0.11.0-amd64

6、将node加入集群(在node端操作)

# kubeadm join 192.168.6.115:6443 --token qgvys8.hv4ix9fj5i9x6awn \
    --discovery-token-ca-cert-hash sha256:e78d2c577f1c8a5114ddd30d86e9fb65a2d9ccd92d00c13f301e11ab71368bac

7、查看集群状态(在master端操作)

# kubectl get nodes

8、测试kubernetes集群(在master端操作)

# kubectl create deployment nginx --image=nginx
# kubectl expose deployment nginx --port=80 --type=NodePort
# kubectl get pod,svc,deployment

9、部署 Dashboard

# https://raw.githubusercontent.com/kubernetes/dashboard/v1.10.1/src/deploy/recommended/kubernetes-dashboard.yaml

注:kubernetes-dashboard.yaml 文件中的镜像地址原本是国外的,访问不了可以改成个人镜像地址:liyupei/kubernetes-dashboard-amd64:v1.10.1

默认Dashboard只能集群内部访问,修改Service为NodePort类型,暴露到外部

kind: Service
apiVersion: v1
metadata:
  labels:
    k8s-app: kubernetes-dashboard
  name: kubernetes-dashboard
  namespace: kube-system
spec:
  type: NodePort
  ports:
    - port: 443
      targetPort: 8443
      nodePort: 30001
  selector:
    k8s-app: kubernetes-dashboard

# kubectl apply -f kubernetes-dashboard.yaml

浏览器输入:https://IP:30001

创建service account并绑定默认cluster-admin管理员集群角色

# kubectl create serviceaccount dashboard-admin -n kube-system
# kubectl create clusterrolebinding dashboard-admin --clusterrole=cluster-admin --serviceaccount=kube-system:dashboard-admin
# kubectl describe secrets -n kube-system $(kubectl -n kube-system get secret | awk '/dashboard-admin/{print $1}')

注:复制下面的token信息到dashboard的令牌处即可登录