设为首页 收藏本站
查看: 2250|回复: 0

[经验分享] 基于Centos7构建Kubernetes平台

[复制链接]

尚未签到

发表于 2018-9-16 06:40:56 | 显示全部楼层 |阅读模式
  防伪码:我已经过了餐桌上有只鸡就一定能吃到鸡腿的年纪了。
  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
  实验过程:
  一.环境搭建:
  3台centos7的主机:
  master 192.168.1.140 部署etcd,kube-apiserver,kube-controller-manager,kube-scheduler 4个应用。
  node01 192.168.1.31  部署docker,kubelet, kube-proxy 3个应用
  node02 192.168.1.11  部署docker,kubelet, kube-proxy 3个应用

  •   修改主机名和ip,三个主机网卡均设置为桥接模式,能够联网。
  •   分别修改/etc/hosts文件:
DSC0000.png


  •   三台均设置防火墙的默认区域为trusted。
DSC0001.png


  •   三台均关闭selinux.
DSC0002.png


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


  •   开启路由转发功能:
DSC0004.png

  二.实现node01和node02之间容器互通。

  •   node01和node02新建网桥,并固定网桥ip。
  node01上操作:
  删除网桥docker0,新建网桥kbr0:
DSC0005.png

  新建网桥的配置文件:
DSC0006.png

  新建路由文件:route-eth0,eth0为node1上的网卡名。
DSC0007.png

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

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

  •   对node02做同样的设置:
  新建网桥:
DSC0009.png

  新建网桥配置文件:
DSC00010.png

  创建路由文件:
DSC00011.jpg

  修改docker 配置文件:
DSC00012.png

  重启系统reboot.

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

DSC00014.png


  •   验证两个宿主机间容器的互通性:
  node01上运行一个容器:
DSC00015.png

  node02上运行一个容器:
DSC00016.png

  容器间互ping:
DSC00017.png

DSC00018.png

  三.在master上部署应用:

  •   安装etcd.
DSC00019.png

  查看etcd配置文件:
DSC00020.png


  •   修改配置文件:
DSC00021.png


  •   启动etcd服务:
DSC00022.png

  查看服务端口号:
DSC00023.png


  •   部署k8s-master组件(apiserver+controller-manager+scheduler)
  安装软件:
DSC00024.png

DSC00025.jpg

  查看配置文件:
DSC00026.png


  •   修改配置文件:
DSC00027.jpg

DSC00028.png

  KUBE_LOGTOSTDERR  //日志设置
  KUBE_LOG_KEVEL     //日志级别设置
  KUBE_ALLOW_PRIV    //是否允许运行特权容器
  KUBE_MASTER        //主节点的地址,主要为replication controller和scheduler及kubelet可以顺利找到apiserver
DSC00029.jpg

DSC00030.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的时候会报错

  •   启动服务:
DSC00031.png

  四.部署node主机:

  •   安装kubernetes-node软件:
DSC00032.jpg

  查看配置文件:
DSC00033.png


  •   修改配置文件:
DSC00034.png

DSC00035.png

DSC00036.jpg

DSC00037.png

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

  •   启动服务:
DSC00038.jpg

  查看端口:
DSC00039.png


  •   在node02主机上重复上面的操作。
  •   在master上检查node 状态:
DSC00040.png

DSC00041.jpg

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

  •   导入镜像:
DSC00042.png


  •   基于私有仓库镜像运行容器
DSC00043.png

  本地访问私有仓库:
DSC00044.png


  •   上传镜像到私有仓库。
  导入之后用到的镜像到本地:
DSC00045.png

  给基础镜像打个标签:
DSC00046.png

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

  重启docker服务:
DSC00048.png

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

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

DSC00051.png

  六.部署web应用

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

DSC00053.png

  然后systemctl restart kubelet.service

  •   创建apache-rc.yaml文件,根据文件内容创建rc和pod。
DSC00054.png

DSC00055.jpg

  查看pods状态:
DSC00056.png

  查看pods详细状态:
DSC00057.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
  Server的type有ClusterIP和 NodePort之分,缺省是ClusterIp,这种类型的service只能在集群内部访问
  创建配置文件:
DSC00058.png

DSC00059.png

  创建service:
DSC00060.jpg

  查看service状态:
DSC00061.png

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

DSC00063.png


  •   部署外部可访问的apache service。
  创建nodeport类型的service .这种类型的Service在集群外部是可以访问
DSC00064.png

DSC00065.png

  创建service:
DSC00066.jpg

  查看service:
DSC00067.png

  验证service的可访问性:
  外部访问:
DSC00068.png

DSC00069.png

  内部访问:
DSC00070.png



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-584125-1-1.html 上篇帖子: Kubernetes、Mesos和Swarm:Rancher编排引擎的比较 下篇帖子: 手动搭建Kubernetes1.8高可用集群(1)Docker配置
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表