CentOS7安装k8s

借鉴博客:https://www.cnblogs.com/xkops/p/6169034.html

啊西吧,啊西吧,根据上面的博客终于安装成功了。妈的,网上大部分博客安装k8s配置写得乱七八槽的,终于找到一篇条理清晰,安装详细的k8s安装博客啦,哈哈哈哈,不容易啊快三个星期了,从狗屁不懂搞这玩意。

下面写一写我自己的安装流程:

  一、安装准备:

      准备两台服务器(我用的是CentOS7系统):192.168.26.227,192.168.26.228

      一主一从:

        master机:192.168.26.227

        node机:192.168.26.228

      简单说一下k8s:

        我们为什么要用k8s集群?

          故障自愈:

            k8s这个玩意可以监控容器运行,我们把项目放到容器里。由于一些外部内部原因服务器承受不住压力,如果主节点上的容器突然挂了,k8s立刻会自己将主机上的服务调度到另一个node机器上运行

          应用更新:

            更新项目上线时不用中断当前项目的运行。

          还有一些自动扩容,缩容的概念就不讲了,我本人也没亲身体会用过,不好说。

      k8s的全生命周期管理:

          在k8s进行管理应用的时候,基本步骤是:创建集群,部署应用,发布应用,扩展应用,更新应用。

    

    Kubernetes集群组件:
        - etcd 一个高可用的K/V键值对存储和服务发现系统
        - flannel 实现夸主机的容器网络的通信
        - kube-apiserver 提供kubernetes集群的API调用
        - kube-controller-manager 确保集群服务
        - kube-scheduler 调度容器,分配到Node
        - kubelet 在Node节点上按照配置文件中定义的容器规格启动容器
        - kube-proxy 提供网络代理服务

      

    上面都是些k8s集群所要用到的组件,具体这些组件都是用来干嘛的呢,我们来好好分析分析。

      master主机上192.168.26.277必须要有的组件:

          etcd  :目前还不是很理解

          kube-apiserver:目前还不是很理解

          kube-scheduler:目前还不是很理解

          kube-controller-manager:目前还不是很理解

      node节点机上192.168.26.228必须要有的组件:

          flannel:好像是用来支持网络通信的吧

          kube-proxy

          kubelet:

          docker:

》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》

下面废话不多说,来进行安装步骤:

  二、k8s安装步骤:

        1、所有机器上执行以下命令,准备安装环境:(注意是所有机器,主机master,从机node都要安装)

          1.1、安装epel-release源

yum -y install epel-release

          1.2、所有机器关闭防火墙

systemctl stop firewalld
systemctl disable firewalld

setenforce 0

      2、现在开始master主机上192.168.26.227安装kubernetes Master

        2.1、使用yum安装etcd、kubernetes-master

yum -y install etcd kubernetes-master

        

        2.2、编辑:vi /etc/etcd/etcd.conf文件,修改结果如下:

        2.3、配置:vi /etc/kubernetes/apiserver文件,配置结果如下:

         2.4、启动etcd、kube-apiserver、kube-controller-manager、kube-scheduler等服务,并设置开机启动。

for SERVICES in etcd kube-apiserver kube-controller-manager kube-scheduler; do systemctl restart $SERVICES;systemctl enable $SERVICES;systemctl status $SERVICES ; done

      

        2.5、在etcd中定义flannel网络

etcdctl mk /atomic.io/network/config '{"Network":"172.17.0.0/16"}'

》》》》》》》》以上master主机上的配置安装什么的都弄完了》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》》

      3、接下来弄node从机上的配置安装什么的

          3.1、在node机上192.168.26.228安装kubernetes Node和flannel组件应用

yum -y install flannel kubernetes-node

          3.2、为flannel网络指定etcd服务,修改/etc/sysconfig/flanneld文件,配置结果如下图:

         3.3、修改:vi /etc/kubernetes/coonfig文件,配置结果如下图:

         3.4、node节点机上启动kube-proxy,kubelet,docker,flanneld等服务,并设置开机启动。

for SERVICES in kube-proxy kubelet docker flanneld;do systemctl restart $SERVICES;systemctl enable $SERVICES;systemctl status $SERVICES; done

       

》》》》》》以上所有master主机,node节点机上的配置就完成了,接下来看看k8s集群是否搭建起来了》》》》》》》》》》》》》》》》》》》

     

      在master主机上192.168.26.227执行如下命令,查看运行的node节点机器:

kubectl get nodes

       成功啦啦啦啦,结果图如下:

嗯,下一篇,怎么使用k8s,或者把项目丢到k8s集群里运行试试它所谓的那些优点功能。

猜你喜欢

转载自www.cnblogs.com/spll/p/10033316.html