CentOS7.5 使用二进制程序部署Kubernetes1.12.2
一、安装方式介绍
1、yum 安装
目前CentOS官方已经把Kubernetes源放入到自己的默认 extras 仓库里面,使用 yum 安装,好处是简单,坏处也很明显,需要官方更新 yum 源才能获得最新版本的软件,而所有软件的依赖又不能自己指定,尤其是你的操作系统版本如果低的话,使用 yum 源安装的 Kubernetes 的版本也会受到限制,通常会低于官方很多版本,我安装的时候目前官方版本为1.12,而 yum 源中的版本为1.5.2。
请查看博文:https://blog.51cto.com/wzlinux/2321767
2、二进制安装
使用二进制文件安装,好处是可以安装任意版本的 Kubernetes,对一些新版本新功能追求的同学比较合适,坏处是配置比较复杂,很多软件包因为一些原因,我们在大陆是访问不到的。
3、Kubeadm 安装
kubeadm 是 Kubernetes 官方提供的用于快速安装 Kubernetes 集群的工具,伴随Kubernetes每个版本的发布都会同步更新,kubeadm会对集群配置方面的一些实践做调整,通过实验 kubeadm 可以学习到 Kubernetes 官方在集群配置上一些新的最佳实践。 请查看博文:https://blog.51cto.com/wzlinux/2322616
这里我们选用第二种方式安装。
二、环境准备
1、软件版本
我们安装的版本基本是目前最新的版本。
软件
版本
kubernetes
v1.12.2
CentOS 7.5
CentOS Linux release 7.5.1804
Docker
v18.06 这是官方推荐的
etcd
3.3.10
flannel
0.10.0
2、节点规划
IP
角色
安装软件
172.18.8.200
k8s master
etcd,kube-apiserver,kube-controller-manager,kube-scheduler,kubelet
172.18.8.201
k8s node01
docker,kubelet,kube-proxy,flannel
172.18.8.202
k8s node02
docker,kubelet,kube-proxy,flannel
节点及网络规划如下:

3、系统配置
关闭防火墙。
配置/etc/hosts,添加如下内容。
关闭SELinux。
关闭swap。
4、二进制软件包下载
我们可以下载编译好的二进制文件,也可以下载源码自己编译,这里只讨论二进制的安装方式。在Kubernetes的Github CHANGELOG日志中可以看到最新的版本号,也可以到Tag页面中找到自己需要的版本,我下载的是 v1.12.2。
上传我们下载的二进制软件包到各节点,并解压在root家目录,查看目录内容。
这些包都是存储在google的服务器上面,因为众所周知的原因,我们是无法访问的,所以需要各位科学上网才可以获取,不过我可以把我获取的包传到网盘分享给大家。 大家可以去下载使用。链接: https://pan.baidu.com/s/1Ut9VERgm55B4lmz0wjjzFQ 提取码: mjem
三、安装master
master节点需要安装的服务有kube-apiserver,kube-controller-manager,kube-scheduler,所以我们先把需要的二进制文件放到环境变量。
创建需要的目录。
1、安装etcd
因为所以的组件都是需要etcd存储,所以我们第一安装的就是etcd,如果不是为了新版本,为了方便可以使用yum安装。
我这里采用二进制安装方法,首先下载安装包。
下载。
解压安装。
创建system启动文件etcd.service。
创建配置文件。
启动etcd。
查看启动状态。
说明: etcd 会启用两个端口,其中2380 是集群的通信端口,2379是服务端口。如果是配置etcd集群,则要修改配置文件,设置监听IP和端口。
2、安装 kube-apiserver
创建启动文件/usr/lib/systemd/system/kube-apiserver.service,修改为如下内容:
创建目录和配置文件。
启动服务。
查看启动是否成功。
kube-apiserver监听在两个端口,6443是https加密通信方式,8080是http的通信方式,我们这里没有配置证书选项,所以我们的通信都是明文通信,官方文档查看。
加密6443的写法:
service-cluster-ip-range是servcies的虚拟IP的IP范围,这里可以自己定义,不能当前的宿主机网段重叠。 bind-addres 指定的apiserver监听地址,对应的监听端口是6443,使用的https的方式。 client-ca-file 这是认证的相关文件,这预先定义,后面会创建证书文件,并放置到对应的路径.
3、安装kube-controller-manager
创建启动文件/usr/lib/systemd/system/kube-controller-manager.service,添加如下内容:
创建配置文件controller-manager,IP根据自己的实际情况进行修改。
启动服务。
验证服务状态。
端口10257为https提供身份验证和授权,10252为默认非加密端口,官方文档查看。
4、安装kube-scheduler
创建启动文件/usr/lib/systemd/system/kube-scheduler.service,添加如下内容:
创建配置文件/etc/kubernetes/scheduler。
启动服务。
验证服务状态。
端口10251是非加密端口,https端口为10259。官方文件查看。
使用 kubectl 查看状态。
四、安装node节点(node01为例)
1、环境准备
node节点需要安装的服务有docker,kubelet,kube-prox,flannel,所以我们先把需要的二进制文件放到环境变量。
加载ipvs内核,使node节点kube-proxy支持ipvs代理规则。
创建需要的目录。
配置转发参数。
2、安装docker-ce
我们使用推荐的版本18.06,此时docker官方的最新版本为18.09,所以我们需要配置官方yum源。
配置加速器。
2、安装 kube-proxy 服务
创建启动文件/usr/lib/systemd/system/kube-proxy.service,添加如下内容:
创建需要的配置文件,IP请根据自己的实际情况进行修改。
启动服务。
查看启动状态。
端口10256负责健康检查,10249负责和server通信,官方文档查看。
3、安装 kubelete 服务
创建启动文件/usr/lib/systemd/system/kubelet.service,新增如下内容:
创建配置文件kubeconfig.yaml,具体参数请根据自己的需求进行修改,新增如下内容:
启动kubelet。
查看启动情况。
配置官方文档请查看。
4、配置flannel网络(Pod使用)
我们之所以要单独使用第三方的网络插件来扩展k8s,主要原因是在使用docker的环境中,在每个node节点的docker0默认的网段都是172.17.0.0/16的网络。如果要实现不同宿主node上pod(这里也可以理解为容器)互相通信,就不能使用默认的docker0提供的网段,我们需要部署一个覆盖网络,让每个node节点的docker0网络都处于不同的网段,这样,通过添加一些路由转发策略,就能让集群中各个pod在同一个虚拟的网络中实现通信。
从github官网下载最新版本。
创建启动文件/usr/lib/systemd/system/flanneld.service,新增如下内容:
对上面的文件做一下解释:
Flannel网络必须在宿主机网络能对外(其它node节点)正常通信的情况下启动才有意义,所以这里定义
After=network.target只有当Flannel 网络启动之后,才能创建一个与其它节点不会冲突的网络,而docker的网络需要和fannel 网络相同才能保证跨主机通信,所以docker必须要在flannel网络创建后才能启动,这里定义
Before=docker.service
创建配置文件/etc/sysconfig/flanneld,设置为如下内容:
在master节点上为 falnnel 创建分配的网络。
在各node节点上启动 flannel。
检查是否启动好。
也可以使用自助安装,官方建议的使用方法。 kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml
5、启动docker
编辑文件/usr/lib/systemd/system/docker.service,修改为如下内容,让docker使用flannel网络。
我们最后启动docker服务。
我们可以看到docker0已经连接到flannel0,并且添加10.244.71.0/24的路由。
五、master节点验证
先运行几个pod看一下。
查看一下pod状态,发现容器的状态为ContainerCreating,使用kubectl describe pod POD_NAME发现在请求k8s.gcr.io/pause:3.1pod镜像模板。
因为我们还没有pod基础设施镜像k8s.gcr.io/pause:3.1,就是所有pod的模板,我们需要从gcr.io下载,但是这个地址我们国内是无法访问的,我们可以使用间接的方法,在所有的node节点上,我们可以从阿里云的镜像下载,然后再tag成我们需要的镜像。
问题解决之后我们再次查看。
当前的网络结构图如下所示:

我们可以创建一个service,查看其分配的IP。
至此,使用二进制程序搭建的过程我们已经介绍完了。
Last updated