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. JavaScript复制内容到剪贴板

    移动端 需要复制内容到剪贴板时, clipborad.js 不支持ios微信版浏览器,可配合使用 execCommand 使其兼容, 完成一键复制淘口令的功能. 注意使用clipborad.js时,i ...

  2. Liblinear Visual studio 2013 Error C3057

    使用LibLinear时编译时出现Error C3057的错误: OpenMP报错,查询MSDN: #pragma omp threadprivate(var)//var在编译之前必须是确定值 所以修 ...

  3. Python - 工具:将大图切片成小图,将小图组合成大图

    训练keras时遇到了一个问题,就是内存不足,将 .fit 改成 .fit_generator以后还是放不下一张图(我的图片是8192×8192的大图==64M).于是解决方法是将大图切成小图,把小图 ...

  4. 统计mysql某个数据库的表数量以及表记录数

        统计MySQL中某个数据库中有多少张表 SELECT count(*) TABLES, table_schema FROM information_schema.TABLES    where ...

  5. Go 结构体与初始化

    Go 通过类型别名(alias types)和结构体的形式支持用户自定义类型. 结构体是复合类型,当需要定义类型,它由一系列属性组成,每个属性都有自己的类型和值的时候,就应该使用结构体,它把数据聚集在 ...

  6. 尚硅谷Docker---1、docker杂记

    尚硅谷Docker---1.docker杂记 一.总结 一句话总结: ~ php用的homestead就相当于docker,javaee一般都是用docker,php也可以用docker ~ dock ...

  7. python:网络爬虫的学习笔记

    如果要爬取的内容嵌在网页源代码中的话,直接下载网页源代码再利用正则表达式来寻找就ok了.下面是个简单的例子: import urllib.request html = urllib.request.u ...

  8. Java-JVM 运行时内存结构(Run-Time Data Areas)

    Java 虚拟机定义了在程序执行期间使用的各种运行时数据区域. 其中一些数据区域所有线程共享,在 Java 虚拟机(JVM)启动时创建,仅在 Java 虚拟机退出时销毁. 还有一些数据区域是每个线程的 ...

  9. git *** Please tell me who you are.错误

    GIT 中提示 please tell me who you are   如果使用git过程中出现了,please tell me who you are ,需要设置一下使用者的身份. 1.git c ...

  10. 在sed中引入shell变量的四种方法

    1.eval sed ’s/$a/$b/’ filename2.sed "s/$a/$b/" filename3.sed ’s/’$a’/’$b’/’ filename 4.sed ...