基于Centos7构建Kubernetes平台

防伪码:我已经过了餐桌上有只鸡就一定能吃到鸡腿的年纪了。


Kubernetes作为Docker生态圈中重要一员,是Google多年大规模容器管理技术的开源版本,是产线实践经验的最佳表现[G1]。如Urs Hlzle所说,无论是公有云还是私有云甚至混合云,Kubernetes将作为一个为任何应用,任何环境的容器管理框架无处不在。正因为如此, 目前受到各大巨头及初创公司的青睐,如Microsoft、VMWare、Red Hat、CoreOS、Mesos等,纷纷加入给Kubernetes贡献代码。随着Kubernetes社区及各大厂商的不断改进、发展,Kuberentes将成为容器管理领域的领导者。

2. 什么是Kubernetes

Kubernetes是Google开源的容器集群管理系统,其提供应用部署、维护、 扩展机制等功能,利用Kubernetes能方便地管理跨机器运行容器化的应用,其主要功能如下:

1) 使用Docker对应用程序包装(package)、实例化(instantiate)、运行(run)。

2) 以集群的方式运行、管理跨机器的容器。

3) 解决Docker跨机器容器之间的通讯问题。

4) Kubernetes的自我修复机制使得容器集群总是运行在用户期望的状态。

当前Kubernetes支持GCE、vShpere


实验过程:

一.环境搭建:

3centos7的主机:

master 192.168.1.140 部署etcd,kube-apiserver,kube-controller-manager,kube-scheduler 4个应用。

node01 192.168.1.31  部署dockerkubelet kube-proxy 3个应用

node02 192.168.1.11  部署dockerkubelet kube-proxy 3个应用

  1. 修改主机名和ip,三个主机网卡均设置为桥接模式,能够联网。

  2. 分别修改/etc/hosts文件:

wKioL1mVPtSTOm_aAAAiZBaGRac058.png

  1. 三台均设置防火墙的默认区域为trusted

wKiom1mVP0SB9noLAAA5GwvIbco643.png

  1. 三台均关闭selinux.

wKiom1mVP1nzlBKmAAAKvs_ol-U424.png

  1. 安装docker,并启动。因为master之后还需要做registry仓库,所以也需要安装docker.

wKiom1mVP2uTfB7cAADuFkIN1K0406.jpg

  1. 开启路由转发功能:

wKiom1mVP-PCkoJSAAA8yERIP6Y306.png

二.实现node01node02之间容器互通。

  1. node01node02新建网桥,并固定网桥ip

node01上操作:

删除网桥docker0,新建网桥kbr0:

wKioL1mVP_-wgiz9AAA57rkzxvA070.png

新建网桥的配置文件:

wKiom1mVQBTgX_YgAAAvqyRSh-M274.png

新建路由文件:route-eth0eth0node1上的网卡名。

wKiom1mVQCSxdvxtAAAwymbbJ20761.png

修改docker配置文件,添加-b=kbr0参数

wKiom1mVQDbTT_FEAAA4sMJQ0dQ991.jpg

reboot重启系统使网桥设置生效。

  1. node02做同样的设置:

新建网桥:

wKioL1mVQE6y5McbAAA-Cs65hTM086.png

新建网桥配置文件:

wKiom1mVQF_RXsZ-AAAy0L676Cs795.png

创建路由文件:

wKioL1mVQIDCyl_CAAAqremADi4872.jpg

修改docker 配置文件:

wKioL1mVQKHgjkR_AAAcYuoI2wQ990.png

重启系统reboot.

  1. 系统启动之后,查看网卡信息和路由信息。


wKioL1mVQLijJHD6AABm3LRkcVg627.png

wKiom1mVQMuyczTEAAAxK2UOd5U713.png

  1. 验证两个宿主机间容器的互通性:

node01上运行一个容器:

wKiom1mVQOizxj1hAAAkemR4fx0354.png

node02上运行一个容器:

wKioL1mVQPbQ6vhJAAAbXf-ydQk012.png

容器间互ping:


wKioL1mVQQ3BpC3kAABM-0eQNrc546.png

wKioL1mVQTTBzIW3AAA8s9twJ9M463.png

三.master上部署应用:

  1. 安装etcd.

wKioL1mVQVLBcsYdAAAHjcyQPaU707.png

查看etcd配置文件:

wKioL1mVQWDgTUC-AAAKah6QPlk609.png

  1. 修改配置文件:

wKiom1mVQXKAmoUIAAB-pHOfjUU138.png

  1. 启动etcd服务:

wKioL1mVQYqz_hFNAABNxaj9h58492.png

查看服务端口号:

wKiom1mVQZez5JvbAAAV_k-zLHk222.png

  1. 部署k8s-master组件(apiserver+controller-manager+scheduler

安装软件:


wKiom1mVQayTKpdVAAAIyVxRuag289.png

wKiom1mVQcTyE8EgAAAiSy6rv9Q206.jpg

查看配置文件:

wKiom1mVQdiwhVAGAAAqO_Fn4bY194.png

  1. 修改配置文件:


wKioL1mVQenQFSj_AAAQ-oGx8mo169.jpg

wKioL1mVQfrCzlfBAABHqGb9t_Y679.png

KUBE_LOGTOSTDERR  //日志设置

KUBE_LOG_KEVEL     //日志级别设置

KUBE_ALLOW_PRIV    //是否允许运行特权容器

KUBE_MASTER        //主节点的地址,主要为replication controllerschedulerkubelet可以顺利找到apiserver

wKiom1mVQg7hxV6BAAAP50c-6pI025.jpg

wKioL1mVQ0qC5Vx3AAEyLPE4mt0154.png


KUBE_API_ADDRESS   //监听的接口,如果配置为127.0.0.1则只监听localhost,配置为0.0.0.0会监听所有接口,这里配置为0.0.0.0

KUBE_API_PORT="--port=8080"   //apiserver的监听端口,默认8080,不用修改。

KUBELET_PORT="--kubelet_port=10250" // kubelet监听的端口,默认10250,无需修改

KUBE_ETCD_SERVERS  //指定etcd节点的地址

KUBE_SERVICE_ADDRESSES  //这个是设置今后运行Service所在的ip网段

KUBE_API_ARGS=”--secure-port=0” //默认是要求https安全通信,”--secure-port=0”则不要求https安全通信

注:这里需要注意原来KUBE_ADMISSION_CONTROL默认包含的要删掉,不然启动APIserver的时候会报错

 

  1. 启动服务:

wKioL1mVQvrhLECPAABpAksRcYg781.jpg

查看服务端口:


wKiom1mVQ2yxCQxVAAAVc1J9-ws012.png

四.部署node主机:

  1. 安装kubernetes-node软件:

wKiom1mVQ4LgPW3FAAAP8dmdlMs679.jpg

查看配置文件:

wKioL1mVQ4-BL05YAAAcbtyADk0154.png

  1. 修改配置文件:

wKiom1mVQ6vQEuybAAAJ_NKjyM8978.png

wKioL1mVQ8fhZp2FAAA2PBlKOR0852.png

wKiom1mVQ9vjhJvfAAAQkajCAms559.jpg

wKioL1mVQ_ajIQ-8AABAJ9iBLnc630.png

配置项KUBELET_POD_INFRA_CONTAINER="--pod-infra-container-image=registry.access.redhat.com/rhel7/pod-infrastructure:latest"作用k8s创建pod的时候需要起一个基本容器,所以node节点要能连网。也可以自己搭建一个私有仓库,将pod-infrastructure:latest镜像上传到私有仓库中,修改此配置文件的地址就可以。

  1. 启动服务:

wKiom1mVRCGTdBvHAABzC9c8EOg120.jpg

查看端口:

wKioL1mVRDfQW1fSAAAfaoKLQis715.png

  1. node02主机上重复上面的操作。

  2. master上检查node 状态:

wKiom1mVRFHQQxRbAAAR1vagReQ713.png

wKiom1mVRG_RMcxTAAApbwyK0ss216.jpg

五.搭建私有仓库:

Kubernetes管理容器如果是第一次操作,可能会有一定的等待时间,这是因为第一次下载images需要一段时间。如果本地没有docker registry,要确保节点能访问互联网,所以我们可以搭建一个私有仓库,由私有仓库提供所需要的镜像,

本实验环境中用kubernetes同时作为registry

 

  1. 导入镜像:

wKioL1mVRIrB4CSnAAARQJT0nA8196.png

  1. 基于私有仓库镜像运行容器

wKiom1mVRN2R4cLhAABZOHrqcQQ131.png

本地访问私有仓库:

wKioL1mVRRyApM4UAAAQslNKDwQ363.png

  1. 上传镜像到私有仓库。

导入之后用到的镜像到本地:

wKioL1mVRViAocQtAAAfavQh8jw060.png

给基础镜像打个标签:

wKioL1mVRWuxilhIAAA_N7vhPmg903.png

在三台主机上均修改docker 的配置文件,指定私有仓库的url.

wKiom1mVRX-BolFlAAAfhEm2Mwg349.png

重启docker服务:

wKioL1mVRZOhAuZ0AABD2eaSqFY404.png

上传镜像到私有仓库并查看:

wKioL1mVRdCygz69AAFrqfdGW_M689.png

测试,下载刚才上传的镜像:


wKioL1mVRgfxeigPAABPDcZSvAE459.png

wKiom1mVRiaCSv0XAAA7BSPA9uY627.png

六.部署web应用

  1. 为了部署pod的时候,下载镜像速度快点,把node节点主机配置文件中的pod镜像下载地址修改为本地私有仓库地址:


wKiom1mVRjqzkrQAAAAPY6vA7Fk573.jpg

wKioL1mVRkrQraPtAABBoLLC7Cw484.png

然后systemctl restart kubelet.service

  1. 创建apache-rc.yaml文件,根据文件内容创建rcpod


wKiom1mVRtuzcsPzAAApTEpjHSM597.png

wKiom1mVRvKD2M_EAAAYx7qXpQU880.jpg

查看pods状态:

wKiom1mVRxyhbAv9AAAWOrx9cZY725.png

查看pods详细状态:

wKioL1mVRy3Q20aPAAAWq6S63cA361.png

附:删除pod

kubectl delete pod podName

由于设置了两份副本,所以删除pod的时候,k8s会迅速起另外一个一模一样的pod以保持副本数量为2不变。

要彻底删除pod,只能删除创建它的replication controller

查看replication controller

kubectl get rc

删除replication controller

kubectl delete rc rcName

删除rc之后,其创建的pod会一并删除

 

3.       部署节点内部可访问的apacheservice

ServertypeClusterIP NodePort之分,缺省是ClusterIp,这种类型的service只能在集群内部访问

创建配置文件:


wKiom1mVR22QfR5vAAAKQLGxj5c614.png

wKioL1mVR4mCuH3YAAAY8qBcOR4405.png

创建service:


wKiom1mVR9GjViJwAAAcDP-l5Wg515.jpg

查看service状态:

wKioL1mVR-bxfmm1AAAcKtJg5VE056.png

验证apache服务:(在node节点执行)


wKiom1mVSBXD8I8gAAAsDj6QMIE556.png

wKioL1mVSD3Bkr9zAAAltkE6-Wc127.png

  1. 部署外部可访问的apache service

创建nodeport类型的service .这种类型的Service在集群外部是可以访问


wKiom1mVSFyTMcWwAAAJ3cdUd2A718.png

wKioL1mVSKfSN-M1AAAb89zBLWg853.png

创建service:

wKiom1mVSL6x-u-tAAA6khuBSTg194.jpg

查看service:

wKioL1mVSM2RFQLrAABMg9Y-Mw4658.png

验证service的可访问性:

外部访问:


wKioL1mVSOHRbx6XAABHj8NvR6Q585.png

wKioL1mVSPvytmU3AAAtD9i0sKE073.png

内部访问:

wKiom1mVSRzTikvUAAAlI8L8BhE594.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值