zoukankan      html  css  js  c++  java
  • 部署K8S集群

    1.Kubernetes

    1.1.概念

      kubernetes(通常称为k8s)用于自动部署、扩展和管理容器化应用程序的开源系统。它旨在提供“跨主机集群的自动部署、扩展以及运行应用程序容器的平台”。支持一系列容器工具  ,包括Docker等。

    1.2.特点

      1)可移植:支持公有云、私有云、混合云、多重云

      2)可扩展:模块化、插件化、可挂载、可组合

      3)自动化:自动部署、自动重启、自动复制、自动伸缩/扩展

      4)快速部署应用,快速扩展应用

      5)无缝对接新的应用功能

      6)节约资源、优化硬件资源的使用

    2.kubernetes中的相关概念

    2.1.Cluster

      计算、存储和网络资源的集合,Kubernetes利用这些资源运行各种基于容器的应用

    2.2Master

      是Cluster的大脑,主要职责是调度,即决定将应用放在哪里运行。Master运行Linux操作系统,可以是物理机或者虚拟机。为了是实现高可用,可以运行多个Master。

    2.3Node

      职责是运行容器应用。Node 由 Master 管理,Node 负责监控并汇报容器的状态,并根据 Master 的要求管理容器的生命周期。Node 运行在 Linux 操作系统,可以是物理机或者是虚拟机。

    2.4Pod

      Pod 是 Kubernetes 的最小工作单元。每个 Pod 包含一个或多个容器。Pod 中的容器会作为一个整体被 Master 调度到一个 Node 上运行。

    2.5Controller

      Kubernetes 通常不会直接创建 Pod,而是通过 Controller 来管理 Pod 的。Controller 中定义了 Pod 的部署特性,比如有几个副本,在什么样的 Node 上运行等。为了满足不同的业务场景,Kubernetes 提供了多种 Controller,包括 Deployment、ReplicaSet、DaemonSet、StatefuleSet、Job 等,

      Deployment 是最常用的 Controller,比如前面在线教程中就是通过创建 Deployment 来部署应用的。Deployment 可以管理 Pod 的多个副本,并确保 Pod 按照期望的状态运行。

      ReplicaSet 实现了 Pod 的多副本管理。使用 Deployment 时会自动创建 ReplicaSet,也就是说 Deployment 是通过 ReplicaSet 来管理 Pod 的多个副本,我们通常不需要直接使用 ReplicaSet。

      

      DaemonSet 用于每个 Node 最多只运行一个 Pod 副本的场景。正如其名称所揭示的,DaemonSet 通常用于运行 daemon。

      

      StatefuleSet 能够保证 Pod 的每个副本在整个生命周期中名称是不变的。而其他 Controller 不提供这个功能,当某个 Pod 发生故障需要删除并重新启动时,Pod 的名称会发生变化。同时 StatefuleSet 会保证副本按照固定的顺序启动、更新或者删除。

      Job 用于运行结束就删除的应用。而其他 Controller 中的 Pod 通常是长期持续运行。

    3.kubernetes核心组件

    3.1组件组成

    image.png

    3.2组件架构图

    image.png

    4.kubernetes分层

    4.1分层架构

    image.png

    4.2分层说明

    image.png

    5.部署K8s集群

    5.1环境准备

    [root@KVM ~]# cat /etc/redhat-release 

    CentOS Linux release 7.4.1708 (Core) 

    [root@KVM ~]# uname -r

    3.10.0-693.el7.x86_64

    [root@KVM ~]# getenforce 

    Disabled

    [root@KVM ~]# systemctl status firewalld.service 

    ● firewalld.service - firewalld - dynamic firewall daemon

       Loaded: loaded (/usr/lib/systemd/system/firewalld.service; disabled; vendor preset: enabled)

       Active: inactive (dead)

         Docs: man:firewalld(1)

    5.2主机IP规划

    image.png

    5.3安装docker(所有节点)

    5.3.1.安装辅助包

    yum install -y device-mapper-persistent-data lvm2 yum-utils

    5.3.2 创建docker源

    yum-config-manager --add-repo  http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

    yum makecache fast

    5.3.3安装docker

    yum install -y docker-ce-17.03.2.ce-1.el7.centos docker-ce-selinux-17.03.2.ce-1.el7.centos

    5.3.4启动docker

    systemctl enable docker && systemctl start docker

    5.4关闭防火墙,关闭selinux(所有节点)

    5.5关闭swap(所有节点)

    [root@k8s-master ~]# swapoff -a

    [root@k8s-master ~]# cat /etc/fstab 

    #

    # /etc/fstab

    # Created by anaconda on Thu Apr 19 20:09:56 2018

    #

    # Accessible filesystems, by reference, are maintained under '/dev/disk'

    # See man pages fstab(5), findfs(8), mount(8) and/or blkid(8) for more info

    #

    /dev/mapper/centos-root /                       xfs     defaults        0 0

    UUID=bef47783-f47e-49a4-ba44-74ee4cbc8606 /boot                   xfs     defaults        0 0

    #/dev/mapper/centos-swap swap                    swap    defaults        0 0

    5.6配置k8s路由(所有节点)

    [root@k8s-master ~]# cat /etc/sysctl.d/k8s.conf 

    net.bridge.bridge-nf-call-ip6tables = 1

    net.bridge.bridge-nf-call-iptables = 1

    [root@k8s-master ~]# sysctl --system

    5.7安装k8s组件(所有节点)

    5.7.1创建k8s源

    cat <<EOF > /etc/yum.repos.d/kubernetes.repo

    [kubernetes]

    name=Kubernetes

    baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/

    enabled=1

    gpgcheck=1

    repo_gpgcheck=1

    gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg

    EOF


    5.7.2安装组件

    yum install -y kubeadm kubectl kubelet

    由于作者所使用的网络无法×××,因此将相关镜像与安装包打包上传到虚拟机,使用rpm安装。

    rpm -ivh socat-1.7.3.2-2.el7.x86_64.rpm

    rpm -ivh kubernetes-cni-0.6.0-0.x86_64.rpm kubelet-1.9.9-9.x86_64.rpm

    rpm -ivh kubectl-1.9.0-0.x86_64.rpm

    rpm -ivh kubeadm-1.9.0-0.x86_64.rpm

    装载k8s镜像

    docker load -i /root/k8s/docker_images/*.tar

    5.7.3启动kubelet并设置自启动(只在master节点操作)

    [root@k8s-master ~]# systemctl enable kubelet && systemctl start kubelet

    如果启动报错,解决方案

    [root@k8s-master ~]# docker info | grep Cgroup

    Cgroup Driver: cgroupfs

    [root@k8s-master ~]# cat /etc/systemd/system/kubelet.service.d/10-kubeadm.conf 

    [Service]

    Environment="KUBELET_KUBECONFIG_ARGS=--bootstrap-kubeconfig=/etc/kubernetes/bootstrap-kubelet.conf --kubeconfig=/etc/kubernetes/kubelet.conf"

    Environment="KUBELET_SYSTEM_PODS_ARGS=--pod-manifest-path=/etc/kubernetes/manifests --allow-privileged=true"

    Environment="KUBELET_NETWORK_ARGS=--network-plugin=cni --cni-conf-dir=/etc/cni/net.d --cni-bin-dir=/opt/cni/bin"

    Environment="KUBELET_DNS_ARGS=--cluster-dns=10.96.0.10 --cluster-domain=cluster.local"

    Environment="KUBELET_AUTHZ_ARGS=--authorization-mode=Webhook --client-ca-file=/etc/kubernetes/pki/ca.crt"

    Environment="KUBELET_CADVISOR_ARGS=--cadvisor-port=0"

    Environment="KUBELET_CGROUP_ARGS=--cgroup-driver=cgroupfs"

    Environment="KUBELET_CERTIFICATE_ARGS=--rotate-certificates=true --cert-dir=/var/lib/kubelet/pki"

    ExecStart=

    ExecStart=/usr/bin/kubelet $KUBELET_KUBECONFIG_ARGS $KUBELET_SYSTEM_PODS_ARGS $KUBELET_NETWORK_ARGS $KUBELET_DNS_ARGS $KUBELET_AUTHZ_ARGS $KUBELET_CADVISOR_ARGS $KUBELET_CGROUP_ARGS $KUBELET_CERTIFICATE_ARGS $KUBELET_EXTRA_ARGS

    5.8设置各个节点的hosts

    cat /etc/hosts

    10.0.0.11 k8s-master

    10.0.0.12 k8s-node-1

    10.0.0.13 k8s-node-2

    5.9在master节点设置ssl(参考文档:https://blog.51cto.com/13520761/2095798)

    ssh-keygen

    ssh-copy-id k8s-node-1

    ssh-copy-id k8s-node-2

    5.10初始化(只在master节点操作)

    [root@k8s-master ~]# kubeadm init --apiserver-advertise-address=10.0.0.11 --pod-network-cidr=10.244.0.0/16 --kubernetes-version=v1.9.0

    5.11验证k8s安装

    [root@k8s-master ~]# kubeadm version

    转自https://blog.51cto.com/13520761/2112274

  • 相关阅读:
    软件測试系列之软件測试过程模型(四)
    实例具体解释Django的 select_related 和 prefetch_related 函数对 QuerySet 查询的优化(二)
    Hadoop-2.2.0中文文档—— MapReduce 下一代
    const vs readonly
    oracle-asm
    Javascript 笔记与总结(2-15)结构、样式、行为分离
    [Swift]LeetCode455. 分发饼干 | Assign Cookies
    [Swift]LeetCode453. 最小移动次数使数组元素相等 | Minimum Moves to Equal Array Elements
    [Swift]LeetCode448. 找到所有数组中消失的数字 | Find All Numbers Disappeared in an Array
    [Swift]LeetCode443. 压缩字符串 | String Compression
  • 原文地址:https://www.cnblogs.com/cangqinglang/p/11369818.html
Copyright © 2011-2022 走看看