环境说明:

节点类型     主机名    管理ip

master          master   192.168.2.10

nodes            node1    192.168.2.11

nodes            node2    192.168.2.12

podSubnet: 10.244.0.0/16

serviceSubnet: 10.96.0.0/16

一、基础环境配置

1、主机名修改

2、关闭防火墙,修改selinux为disable

3、/etc/hosts文件解析

4、关闭swap,或者删除swap分区

5、NTP时间同步

6、Master节点和node节点免密登录

7、配置yum源

  vim /etc/yum.repos.d/kubernetes.repo

  [kubernetes]

  name=Kubernetes

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

  enabled=1

  gpgcheck=0

  repo_gpgcheck=0

  gpgkey=http://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg

       http://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg

二、master节点部署

1、安装docker、kubelet、kubeadm、kubectl软件

  yum install -y docker kubelet kubeadm kubectl

  systemctl restart docker.service

  systemctl enable docker.service

  systemctl status docker.service

  systemctl enable kubelet.service

2、修改kubeadm镜像源

  查看kubeadm需要的镜像,默认需要访问Google,国内一般无法访问,需要修改镜像下载地址

  kubeadm config images list

  kubeadm config print init-defaults > kubeadm.conf

  将kubeadm.conf配置文件中的imageRepository: k8s.gcr.io改为新的地址,如imageRepository:registry.aliyuncs.com/google_containers,或imageRepository: docker.io/mirrorgooglecontainers

  将podSubnet: ''改为需要的地址段,比如podSubnet: 10.244.0.0/16

3、下载需要的镜像

  kubeadm config images list --config kubeadm.conf

  kubeadm config images pull --config kubeadm.conf

4、设置bridge-nf-call-iptables

  echo 1 > /proc/sys/net/bridge/bridge-nf-call-iptables

  echo 1 > /proc/sys/net/bridge/bridge-nf-call-ip6tables

注意:如果不设置,下步执行命令会报错提示

5、初始化kubeadm

  kubeadm init --config kubeadm.conf

  初始化完成会有如下信息输出:

  ---------------------------------------------------------------------------------------------------

  Your Kubernetes control-plane has initialized successfully!

  To start using your cluster, you need to run the following as a regular user:

      mkdir -p $HOME/.kube

     sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config

     sudo chown $(id -u):$(id -g) $HOME/.kube/config

  You should now deploy a pod network to the cluster.

  Run "kubectl apply -f [podnetwork].yaml" with one of the options listed at:

      https://kubernetes.io/docs/concepts/cluster-administration/addons/

  Then you can join any number of worker nodes by running the following on each as root:

    kubeadm join 192.168.2.10:6443 --token abcdef.0123456789abcdef  --discovery-token-ca-cert-hash sha256:06e6c6592362baa34e15ea169b43d16b57361110546b9c5d65b585a8ad09cdd5

  ---------------------------------------------------------------------------------------------------------

6、初始化完成执行如下命令

  mkdir -p $HOME/.kube

  sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config

  sudo chown $(id -u):$(id -g) $HOME/.kube/config

7、设置命令自动补全

  echo "source <(kubectl completion bash)" >> ~/.bashrc

三、node节点操作

1、安装docker、kubelet、kubeadm、kubectl软件

  yum install -y docker kubelet kubeadm kubectl

  systemctl restart docker.service

  systemctl enable docker.service

  systemctl status docker.service

2、设置bridge-nf-call-iptables

  echo 1 > /proc/sys/net/bridge/bridge-nf-call-iptables

  echo 1 > /proc/sys/net/bridge/bridge-nf-call-ip6tables

3、node节点接入集群

  kubeadm join 192.168.2.10:6443 --token abcdef.0123456789abcdef  --discovery-token-ca-cert-hash sha256:06e6c6592362baa34e15ea169b43d16b57361110546b9c5d65b585a8ad09cdd5

四、master节点部署flannel网络

1、master节点部署flannel网络

  wget https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

  kubectl apply -f kube-flannel.yml

2、查看节点信息

  [root@master ~]# kubectl get nodes

  NAME         STATUS     ROLES     AGE   VERSION

  master        Ready          master      3h6m   v1.14.1

  node1        Ready          <none>     125m   v1.14.1

  node2        NotReady    <none>      115m   v1.14.1

3、修改node节点的role属性

  kubectl edit nodes node1

  将node-role.kubernetes.io/node: ""写在label字段里

  kubectl get pods -n kube-system -o wide

kubeadm进行K8S集群部署的更多相关文章

  1. 用kubeadm构建k8s集群部署

    一.环境 三台centos机器 二.软件及容器准备 1.安装docker环境 本例安装 docker-ce版本,repo源为docker-ce.repo文件,拷贝到 /etc/yum.repos.d下 ...

  2. 使用Kubeadm创建k8s集群之部署规划(三十)

    前言 上一篇我们讲述了使用Kubectl管理k8s集群,那么接下来,我们将使用kubeadm来启动k8s集群. 部署k8s集群存在一定的挑战,尤其是部署高可用的k8s集群更是颇为复杂(后续会讲).因此 ...

  3. 使用Kubeadm创建k8s集群之节点部署(三十一)

    前言 本篇部署教程将讲述k8s集群的节点(master和工作节点)部署,请先按照上一篇教程完成节点的准备.本篇教程中的操作全部使用脚本完成,并且对于某些情况(比如镜像拉取问题)还提供了多种解决方案.不 ...

  4. kubeadm搭建K8s集群及Pod初体验

    基于Kubeadm 搭建K8s集群: 通过上一篇博客,我们已经基本了解了 k8s 的基本概念,也许你现在还是有些模糊,说真的我也是很模糊的.只有不断地操作去熟练,强化自己对他的认知,才能提升境界. 我 ...

  5. 二进制方法-部署k8s集群部署1.18版本

    二进制方法-部署k8s集群部署1.18版本 1. 前置知识点 1.1 生产环境可部署kubernetes集群的两种方式 目前生产部署Kubernetes集群主要有两种方式 kuberadm Kubea ...

  6. Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录

    0.目录 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.感谢 在此感谢.net ...

  7. Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之集群部署环境规划(一)

    0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.环境规划 软件 版本 ...

  8. Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之自签TLS证书及Etcd集群部署(二)

    0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.服务器设置 1.把每一 ...

  9. Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列之flanneld网络介绍及部署(三)

    0.前言 整体架构目录:ASP.NET Core分布式项目实战-目录 k8s架构目录:Kubernetes(k8s)集群部署(k8s企业级Docker容器集群管理)系列目录 一.flanneld介绍 ...

随机推荐

  1. 实例详解jQuery的无new构建

    jQuery的无new构建 jQuery框架的核心就是从HTML文档中匹配元素并对其执行操作. 回想一下使用 jQuery 的时候,实例化一个 jQuery 对象的方法: // 无 new 构造 $( ...

  2. python爬取信息并保存至csv

    import csv import requests from bs4 import BeautifulSoup res=requests.get('http://books.toscrape.com ...

  3. 关于SpringMVC映射模型视图的几点小事

    一.SpringMVC概述 SpringMVC为展现层提供的基于MVC设计理念的优秀的Web框架,是目前最主流的MVC框架之一. SpringMVC通过一套MVC注解,让POJO成为处理请求的控制器, ...

  4. python+requests模拟登陆 学校选课系统

    最近学校让我们选课,每天都有不同的课需要选....然后突发奇想试试用python爬学校选课系统的课程信息 先把自己的浏览器缓存清空,然后在登陆界面按f12 如图: 可以看到登陆时候是需要验证码的,验证 ...

  5. JDBC 插入时间字段的值

    ps.setTimestamp(6, new Timestamp(System.currentTimeMillis()));

  6. go语言入门(6)复合类型

    1,分类 2,指针 指针是一个代表着某个内存地址的值.这个内存地址往往是在内存中存储的另一个变量的值的起始位置. 1)基本操作 Go语言虽然保留了指针,但与其它编程语言不同的是: 默认值 nil,没有 ...

  7. Spring Cloud(六)服务网关 zuul 快速入门

    服务网关是微服务架构中一个不可或缺的部分.通过服务网关统一向外系统提供REST API的过程中,除了具备服务路由.均衡负载功能之外,它还具备了权限控制等功能.Spring Cloud Netflix中 ...

  8. CAFFE(FAQ.1):Ubuntu 配置caffe 框架之数据库读取错误:ImportError: No module named lmdb解决办法

    Z: 在安装了caffe框架后需要读取大量的数据进行学习训练.比如在MNIST识别训练中,一般直接读图片会比较耗时,我们一般将图片转存为数据库中.目前主流的数据库有以下两种选择: LevelDB Lm ...

  9. GITHUB readme基本语法

    一.标题写法: 第一种方法: 1.在文本下面加上 等于号 = ,那么上方的文本就变成了大标题.等于号的个数无限制,但一定要大于0个哦.. 2.在文本下面加上 下划线 - ,那么上方的文本就变成了中标题 ...

  10. Java中的集合(上):概述、Collection集合、List集合及其子类

    一.集合的体系结构 二.Collection集合 1.基本使用 如下代码 import java.util.ArrayList; import java.util.Collection; public ...