安装kubenetes有5种部署工具,分别是kubeadm、kops、KRIB、Kubespray。本实验采用的是kubeadm部署工具。如有想了解其他部署工具,请点击这里

环境说明

角色/主机名

系统版本

CPU

MEM

IP

master

CentOS 7.7

4

4

192.168.100.80

node01

CentOS 7.7

4

4

192.168.100.81

node02

CentOS 7.7

4

4

192.168.100.82

注:系统版本要求7.4+

环境准备

检查网络(三个主机)

ping baidu.com

检查端口

Control-plane node

Protocol

Port Range

Purpose

TCP

6443

Kubernetes API server

TCP

2379-2380

etcd server client API

TCP

10250

Kubelet API

TCP

10251

kube-scheduler

TCP

10252

kube-controller-manager

Worker node(s)

Protocol

Port Range

Purpose

TCP 10250 Kubelet API
TCP 30000-32767 NodePort Services**

设置主机名映射(三个主机)

vim /etc/hosts

192.168.100.80    master
192.168.100.81    node01
192.168.100.82    node02

关闭防火墙和selinux(三个主机)

systemctl stop firewalld

systemctl disable firewalld

setenforce 0

sed -ri 's/(^SELINUX=).*/\1disabled/' /etc/selinux/config

配置docker和kubernetes源(三个节点)

yum install wget –y

cd /etc/yum.repos.d && wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo && cd -

cat >> /etc/yum.repos.d/kubernetes.repo <<EOF
[kubernetes]
name=Aliyun-kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64/
enabled=1
gpgcheck=0
EOF

下载docker(三个主机)

yum install docker-ce-18.06.3.ce-3.el7 -y

设置docker加速器和Cgroup drivers

mkdir /etc/docker

vim /etc/docker/daemon.json

{

"exec-opts": ["native.cgroupdriver=systemd"],

"registry-mirrors": ["https://registry.docker-cn.com"]

}

启动docker并设置开机自启动(三个主机)

systemctl start docker.service

systemctl enable docker.service

查看docker版本

docker --version

安装kubeadm, kubelet and kubectl(master)

yum install kubelet kubeadm kubectl –y

安装kubeadm,kubelet(nodes)

yum install kubelet kubeadm -y

设置Cgroup drivers和交换分区(三个主机)

vim /etc/sysconfig/kubelet

KUBELET_EXTRA_ARGS="--fail-swap-on=false --cgroup-driver=systemd"

说明:

--fail-swap-on:关闭交换分区,kubernetes不允许开启交换分区

--cgroup-driver:指定Cgroup drivers用谁

设置kubectl开机自启动(三个主机)

systemctl enable --now kubelet

设置必须的sysctl参数,让这些参数重启后仍然生效

cat > /etc/sysctl.d/99-kubernetes-cri.conf <<EOF
net.bridge.bridge-nf-call-iptables = 1
net.ipv4.ip_forward = 1
net.bridge.bridge-nf-call-ip6tables = 1
EOF

sysctl --system

使用kubernetes创建单个控制平面集群(master)

kubeadm init --kubernetes-version=v1.16.3 --image-repository registry.aliyuncs.com/google_containers --pod-network-cidr=10.244.0.0/16 --service-cidr=10.96.0.0/12  --ignore-preflight-errors=Swap

说明:

--kubernetes-version:为控制平面选择特定的Kubernetes版本。

--image-repository :指定镜像部署的地址,原地址https://k8s.gcr.io不可用

--pod-network-cidr:pod的网络地址

--service-cidr:server的网络地址

是输出一段字符保持好,后面需要用到

kubeadm join 192.168.100.80:6443 --token oc5h3c.bs1gikpbvgzbc86y \

--discovery-token-ca-cert-hash sha256:e0e176b55cb5fbf1238351e8d009bf8cc1f9a69a283a47c9ec5766564657d6a0

每次启动自动加载$HOME/.kube/config下的密钥配置文件(master)

mkdir -p $HOME/.kube

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

将nodes主机加入kubernetes集群(nodes)

kubeadm join 192.168.100.80:6443 --token oc5h3c.bs1gikpbvgzbc86y --discovery-token-ca-cert-hash sha256:e0e176b55cb5fbf1238351e8d009bf8cc1f9a69a283a47c9ec5766564657d6a0 --ignore-preflight-errors=Swap

注意:红色部分是上面复制好的内容,加上黄色部分,请仔细看别忘了两个横杠。

安装flannel网络(master)

kubectl apply -f https://raw.githubusercontent.com/coreos/flannel/master/Documentation/kube-flannel.yml

验证:

查看kubernetes启动的docker容器

[root@master ~]# kubectl get -A pods -o wide

查看kubernetes集群节点

[root@master ~]# kubectl get nodes

查看各服务器的镜像

docker image list

查看下个内容kubernetes资源清单之pod点击这里

遇到什么报错,欢迎评论

采用kubeadm部署工具,部署kubernetes1.16.3的更多相关文章

  1. KingbaseES集群部署工具安装

    关键字: KingbaseES.Java.ClientTools 一.安装前准备 1.1 软件环境要求 金仓数据库管理系统KingbaseES V8.0支持微软Windows 7.Windows XP ...

  2. 通过kubeadm工具部署k8s集群

    1.概述 kubeadm是一工具箱,通过kubeadm工具,可以快速的创建一个最小的.可用的,并且符合最佳实践的k8s集群. 本文档介绍如何通过kubeadm工具快速部署一个k8s集群. 2.主机规划 ...

  3. 使用kubeadm安装kubernetes/部署前准备/flannel网络插件/镜像下载/

    本文内容参考<kuberneters进阶实战>/马哥的新书/推荐 部署前的准备 主机名称解析 分布式系统环境中的多主机通信通常基于主机名称进行,这在IP地址存在变化的可能性时为主机提供了固 ...

  4. 简化kubernetes应用部署工具之Helm应用部署

    介绍 微服务和容器化给复杂应用部署与管理带来了极大的挑战.Helm是目前Kubernetes服务编排领域的唯一开源子项目,做为Kubernetes应用的一个包管理工具,可理解为Kubernetes的a ...

  5. 使用开源Breeze工具部署Kubernetes 1.12.1高可用集群

    Breeze项目是深圳睿云智合所开源的Kubernetes图形化部署工具,大大简化了Kubernetes部署的步骤,其最大亮点在于支持全离线环境的部署,且不需要FQ获取Google的相应资源包,尤其适 ...

  6. 简化Kubernetes应用部署工具-Helm

    [编者的话]微服务和容器化给复杂应用部署与管理带来了极大的挑战.Helm是目前Kubernetes服务编排领域的唯一开源子项目,做为Kubernetes应用的一个包管理工具,可理解为Kubernete ...

  7. 使用睿云智合开源 Breeze 工具部署 Kubernetes v1.12.3 高可用集群

    一.Breeze简介 Breeze 项目是深圳睿云智合所开源的Kubernetes 图形化部署工具,大大简化了Kubernetes 部署的步骤,其最大亮点在于支持全离线环境的部署,且不需要FQ获取 G ...

  8. Spark1.0.0 应用程序部署工具spark-submit

    原文链接:http://blog.csdn.net/book_mmicky/article/details/25714545 随着Spark的应用越来越广泛,对支持多资源管理器应用程序部署工具的需求也 ...

  9. Flask采用Virtualenv+Supervisor+Nginx部署应用

    Flask采用Virtualenv+Supervisor+Nginx部署应用 -- 首先是概念解释 WSGI服务器,负责我们的app与服务器的交互,常用的有Gunicorn Web服务器,是个HTTP ...

随机推荐

  1. SpringBoot搭建聚合项目-实战记录01

    工具:Spring Tool Suite 4 项目搭建 1.首先建立工作集 : Configure Working Sets -> New.. ->设置名称(如project) -> ...

  2. 《精通并发与Netty》学习笔记(05 - Google Protobuf与Netty的结合)

    protobuf是由Google开发的一套对数据结构进行序列化的方法,可用做通信协议,数据存储格式,等等.其特点是不限语言.不限平台.扩展性强 Netty也提供了对Protobuf的天然支持,我们今天 ...

  3. NDK学习笔记-C语言

    本文简要回顾了C语言的一些注意事项和理解细节,不再赘述C语言的所有语法 头文件 头文件作为引入文件,在编译的时候,加载到源代码,参与编译 在VS2013中可以看到,当引入头文件时候,只能看到函数的声明 ...

  4. IntelliJ IDEA 2019.2.1 破解教程, 最新激活码(激活到2089年8月,亲测有效,持续更新中...)

    当前最新版本 IDEA 2019.2.1 本来笔者这边是有个正版激活码可以使用的,但是,2019.9月3号的时候,一些小伙伴反映这个注册码已经失效了,于是拿着自己的 IDEA, 赶快测试了一下,果不其 ...

  5. Linux用户管理命令介绍

    1)管理用户命令总汇 2)管理用户组命令 总汇

  6. ubuntu 16.04主题美化

    目录 numix图标 Flatabulous主题 参考: Unity-tweak-tool插件 numix图标 sudo apt-add-repository ppa:numix/ppa sudo a ...

  7. csv文件的读取写法 from Udacity

    长版本 import unicodecsv enrollments_filename = 'C:\\Users\\xxxxx\\Desktop\\try.csv' enrollments = [] f ...

  8. 贪心学院 scrapy爬虫

    生成爬虫 scrapy genspider 爬虫名 网址 打开调试用shell scrapy shell 网址 主体 stock.py # -*- coding: utf-8 -*- import r ...

  9. 2019icpc银川网络赛

    外面吵得风生水起,我校平静地在打比赛,丝毫不知道这次比赛的题目就是把2018银川邀请赛的题照搬过来了QAQ,主办方真牛逼.. A Maximum(思维) 题意:维护一个栈,支持入栈和出栈操作,并计算每 ...

  10. 自定义函数(function)

    USE [NC] GO /****** Object: UserDefinedFunction [dbo].[dict_url_channel] Script Date: 2019/5/25 16:4 ...