1. 本教程是在VM中搭建K8s 所以第一步骤先配置虚拟机的ip 和上网情况详细参考https://www.cnblogs.com/chongyao/p/9209527.html
  2. 开始搭建K8s集群
    • 两台机器一台master 一台node

      master:192.168.211.150
      node1: 192.168.211.151
    • master 和node 都需要进行的准备工作
      • #修改hostname

        #master 对应master node 对应node
        hostnamectl set-hostname master
        hostnamectl set-hostname node1
      • 关闭所有节点的SELinux,关闭防火墙,等一系列准备安装操作
        #修改/etc/selinux/config文件中设置SELINUX=disabled ,然后重启服务器。
        vi /etc/selinux/config
        setenforce
        systemctl stop firewalld
        systemctl disable firewalld
        swapoff -a
        vi /etc/fstab (注释最后一行)
        echo > /proc/sys/net/bridge/bridge-nf-call-iptables
        echo > /proc/sys/net/ipv4/ip_forward
        echo > /proc/sys/net/bridge/bridge-nf-call-ip6tables
      • 安装最新版docker 参考https://www.cnblogs.com/chongyao/p/9082902.html
      • 添加docker 镜像加速,和一些配置
        sudo mkdir -p /etc/docker
        sudo tee /etc/docker/daemon.json <<-'EOF'
        {
        "exec-opts": ["native.cgroupdriver=systemd"],
        "log-driver": "json-file",
        "log-opts": {
        "max-size": "100m"
        },
        "storage-driver": "overlay2",
        "storage-opts": [
        "overlay2.override_kernel_check=true"
        ],
        "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"]
        }
        EOF
        sudo systemctl daemon-reload
        sudo systemctl restart docker
      • 配置源  安装kubeadm  kubelet kubectl
        cat>>/etc/yum.repos.d/kubrenetes.repo<<EOF
        [kubernetes]
        name=Kubernetes Repo
        baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
        gpgcheck=
        gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg
        EOF yum install -y kubeadm kubelet kubectl
        systemctl start docker.service
        systemctl enable docker.service
        systemctl enable kubelet.service
    • master 进行准备工作之后需要做的工作
      #使用kubeadm init 节点(这里最后一个环境变量k8s版本跟你安装的k8s版本要对上)
      kubeadm init --image-repository registry.aliyuncs.com/google_containers --pod-network-cidr=10.244.0.0/ --ignore-preflight-errors=cri --kubernetes-version=1.15.
      #配置kubectl 环境变量conf
      sudo cp /etc/kubernetes/kubelet.conf $HOME/
      sudo chown $(id -u):$(id -g) $HOME/kubelet.conf
      export KUBECONFIG=$HOME/kubelet.conf
      #初始化网络插件 Flannel (这里需要注意先用docker pull 链接地址配置相关的image到本地然后再执行 kubectl apply 命令)
      kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/a70459be0084506e4ec919aa1c114638878db11b/Documentation/kube-flannel.yml
      #Master生成token
      kubeadm token create --print-join-command
      生成示例:kubeadm join 192.168.211.150: --token 6v6fja.dmsi0exuxl4p6fhq --discovery-token-ca-cert-hash sha256:618235581f985da7269f3f0993de8de57af263ab46b1b8b4f614e7b679c2cbb7
    • node 进行准备工作之后需要做的工作
      #根据token 加入到master 集群
      kubeadm join 192.168.211.150: --token 6v6fja.dmsi0exuxl4p6fhq --discovery-token-ca-cert-hash sha256:618235581f985da7269f3f0993de8de57af263ab46b1b8b4f614e7b679c2cbb7
    • 最终实现效果
  3. 一些需要注意的问题和解决方案
    #可能遇到的问题:
    . [preflight] Some fatal errors occurred:
    /proc/sys/net/bridge/bridge-nf-call-iptables contents are not set to
    #解决方案:
    echo > /proc/sys/net/bridge/bridge-nf-call-iptables
    echo > /proc/sys/net/ipv4/ip_forward
    echo > /proc/sys/net/bridge/bridge-nf-call-ip6tables
    #问题2: Container runtime network not ready: NetworkReady=false reason:NetworkPluginNotReady
    Flannel 网络插件没装好
    #问题3: Failed to get system container stats for "/system.slice/docker.service":o get container info for "/system.slice/docker.service": unknown container "/system.slice/docker.service"
    修改docker daemon.json
  4. 一些比较常用的命令
    kubectl get pods --all-namespaces  获取所有的命名空间
    kubectl get nodes 获取节点
    kubectl get sa 获取用户
    kubectl get secret
    kubectl describe secret 获取默认用户token
    journalctl -f -u kubelet #错误排查查看日志

Centos 安装k8s 集群(单master开发环境)的更多相关文章

  1. centos安装k8s集群

     准备工作 关闭swap,注释swap分区 swapoff -a 配置内核参数,将桥接的IPv4流量传递到iptables的链 cat > /etc/sysctl.d/k8s.conf < ...

  2. k8s集群———单master节点2node节点

    #部署node节点 ,将kubelet-bootstrap用户绑定到系统集群角色中(颁发证书的最小权限) kubectl create clusterrolebinding kubelet-boots ...

  3. k8s学习笔记之二:使用kubeadm安装k8s集群

    一.集群环境信息及安装前准备 部署前操作(集群内所有主机): .关闭防火墙,关闭selinux(生产环境按需关闭或打开) .同步服务器时间,选择公网ntpd服务器或者自建ntpd服务器 .关闭swap ...

  4. [k8s]kubespray(ansible)自动化安装k8s集群

    kubespray(ansible)自动化安装k8s集群 https://github.com/kubernetes-incubator/kubespray https://kubernetes.io ...

  5. yum安装k8s集群

    k8s的安装有多种方式,如yum安装,kubeadm安装,二进制安装等.本文是入门系列,只是为了快速了解k8s的原理和工作过程,对k8s有一个快速的了解,这里直接采用yum安装 的1.5.2为案例进行 ...

  6. 冰河教你一次性成功安装K8S集群(基于一主两从模式)

    写在前面 研究K8S有一段时间了,最开始学习K8S时,根据网上的教程安装K8S环境总是报错.所以,我就改变了学习策略,先不搞环境搭建了.先通过官网学习了K8S的整体架构,底层原理,又硬啃了一遍K8S源 ...

  7. kubernetes教程第一章-kubeadm高可用安装k8s集群

    目录 Kubeadm高可用安装k8s集群 kubeadm高可用安装1.18基本说明 k8s高可用架构解析 kubeadm基本环境配置 kubeadm基本组件安装 kubeadm集群初始化 高可用Mas ...

  8. Blazor+Dapr+K8s微服务之基于WSL安装K8s集群并部署微服务

         前面文章已经演示过,将我们的示例微服务程序DaprTest1部署到k8s上并运行.当时用的k8s是Docker for desktop 自带的k8s,只要在Docker for deskto ...

  9. 使用kubeadm安装k8s集群故障处理三则

    最近在作安装k8s集群,测试了几种方法,最终觉得用kubeadm应该最规范. 限于公司特别的网络情况,其安装比网上不能访问google的情况还要艰难. 慢慢积累经验吧. 今天遇到的三则故障记下来作参考 ...

随机推荐

  1. 题解 POJ1149 Pigs

    先翻译一下吧(题面可以在原OJ上找) Mirko在一个由M个锁着的猪舍组成的养猪场工作,Mirko无法解锁任何猪舍,因为他没有钥匙.客户纷纷来到农场.他们每个人都有一些猪舍的钥匙,并想购买一定数量的猪 ...

  2. JMS 重点是JMS消息结构讲解

    这部分之前认识的不是很清楚,转载记录下,转载自:https://www.cnblogs.com/Zender/p/9098410.html 阅读目录 一,消息服务 二,JMS 回到目录 小时(1000 ...

  3. Listview操作

    设置 listView1.VirtualMode = true;   listView1.RetrieveVirtualItem += ListView1_RetrieveVirtualItem; p ...

  4. xml配置文件 操作

    public class ConfigFile { protected readonly string configBasePath = "Root/Config"; /// &l ...

  5. FZU - 2218 Simple String Problem 状压dp

    FZU - 2218Simple String Problem 题目大意:给一个长度为n含有k个不同字母的串,从中挑选出两个连续的子串,要求两个子串中含有不同的字符,问这样的两个子串长度乘积最大是多少 ...

  6. fanout(Publish/Subscribe)发布/订阅

    引言 它是一种通过广播方式发送消息的路由器,所有和exchange建立的绑定关系的队列都会接收到消息 不处理路由键,只需要简单的将队列绑定到交换机上 fanout交换机转发消息是最快的,它不需要做路由 ...

  7. better-scroll 介绍

    碰到一个项目,应该遵守两大规则: 1. 不要让项目产生过多的第三方依赖 2. 增强组件的应用率 尽可能的将东西写在组件里面,尽可能的将数据写活,通过组件通信来进行数据转换,用到的依赖处理,我们可以通过 ...

  8. PHP JQurey

    JQuery是用JS编写的程序,使用起来比JS更为简单,使用前需引入一个JQurey文件,下面为JQurey语法 <script type="text/javascript" ...

  9. [论文理解] FoveaBox: Beyond Anchor-based Object Detector

    FoveaBox: Beyond Anchor-based Object Detector Intro 本文是一篇one-stage anchor free的目标检测文章,大体检测思路为,网络分两路, ...

  10. LC 763. Partition Labels

    A string S of lowercase letters is given. We want to partition this string into as many parts as pos ...