Kubernetes二进制部署

本文介绍如何部署Kubernetes,由于基础设施环境多样,本文部署情况仅仅针对裸机或虚拟机环境,暂不支持公有云如GCE,AWS,DigitOcean环境,也不支持直接与虚拟化系统如ESXi进行部署。

部署方式

Kubernetes部署方式分为两种,二进制方式或容器化方式

  1. 二进制:直接部署所有组件到主机
  2. 容器化:所有组件在容器内方式运行

二进制部署Kubernetes

一、依赖

  • docker-engine 1.12
  • ubuntu14.04

二、下载安装包

下载k8s_install_binariesmaster机器,解压安装包

进入cluster目录,编辑setup.sh脚本文件

需要根据具体部署的集群信息更新setup.sh脚本文件

  • nodes:所有节点信息username@ip,以空格分开,第一个默认为master节点
  • rolesa代表masteri代表nodeai代表master node,定义nodes参数所有节点的角色信息
  • NUM_NODES:节点数量,集群共有多少节点
  • SERVICE_CLUSTER_IP_RANGE:定义service IP范围,给定一个私有IP范围,确保不要和本地私有IP 冲突
  • FLANNEL_NET:定义flannel overlay网络地址,确保不要与SERVICE_CLUSTER_IP_RANGE冲突。

赋予setup.sh执行权限,并执行setup.sh脚本

重要:如果机器没有ssh秘钥,则生成秘钥文件,可以不输入直接回车自动生成

安装过程中,需要输入多次master节点和node节点的密码信息,执行结束会得到如下提示

master节点查看节点信息,验证集群状态

root@k8s-master:/home/ubuntu/k8s_install_binaries/cluster# kubectl get nodes
NAME           STATUS    AGE
192.168.3.44   Ready     5m
192.168.3.48   Ready     4m

root@k8s-master:/home/ubuntu/k8s_install_binaries/cluster# ps -ef