Kubernetes安装教程
文章目录前言一、Kubernetes是什么?特点:结构:二、安装步骤1.环境要求2.安装目标3.准备环境标题总结前言kubernetes,简称K8s,是用8代替名字中间的8个字符“ubernete”而成的缩写。是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes的目标是让部署容器化的应用简单并且高效(powerful),Kubernetes提供了应用部署,规划,更新,维护的
文章目录
- 前言
- 一、Kubernetes是什么?
- 二、安装步骤
- 1.环境要求
- 2.安装目标
- 3.准备环境
- 4.所有节点安装Docker/kubeadm/kubelet
- 4.1 安装Docker
- 4.2 开启自启和启动
- 4.3 查看版本
- 4.4 添加阿里云YUM的软件源
- 4.5 安装kubeadm,kubelet和kubectl
- 5. 部署Kubernetes Master
- 5. 部署Kubernetes Master
- 5.1 配置
- 5.2 使用kubectl工具:
- 5.3 安装Pod网络插件(CNI)
- 6. 加入Kubernetes Node
- 6.1 在node上安装flannel
- 6.2 向集群添加新节点
- 7. 部署 Dashboard
- 7.1 先Docker拉去镜像
- 7.2 执行kubernetes-dashboard.yaml 文件
- 7.3 访问 Dashboard的web界面
前言
kubernetes,简称K8s,是用8代替名字中间的8个字符“ubernete”而成的缩写。是一个开源的,用于管理云平台中多个主机上的容器化的应用,Kubernetes的目标是让部署容器化的应用简单并且高效(powerful),Kubernetes提供了应用部署,规划,更新,维护的一种机制。
新的方式是通过部署容器方式实现,每个容器之间互相隔离,每个容器有自己的文件系统 ,容器之间进程不会相互影响,能区分计算资源。相对于虚拟机,容器能快速部署,由于容器与底层设施、机器文件系统解耦的,所以它能在不同云、不同版本操作系统间进行迁移。
容器占用资源少、部署快,每个应用可以被打包成一个容器镜像,每个应用与容器间成一对一关系也使容器有更大优势,使用容器可以在build或release 的阶段,为应用创建容器镜像,因为每个应用不需要与其余的应用堆栈组合,也不依赖于生产环境基础结构,这使得从研发到测试、生产能提供一致环境。类似地,容器比虚拟机轻量、更“透明”,这更便于监控和管理。
一、Kubernetes是什么?
Kubernetes是Google开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。在生产环境中部署一个应用程序时,通常要部署该应用的多个实例以便对应用请求进行负载均衡。
在Kubernetes中,我们可以创建多个容器,每个容器里面运行一个应用实例,然后通过内置的负载均衡策略,实现对这一组应用实例的管理、发现、访问,而这些细节都不需要运维人员去进行复杂的手工配置和处理。
特点:
可移植: 支持公有云,私有云,混合云,多重云(multi-cloud)
可扩展: 模块化,插件化,可挂载,可组合
自动化: 自动部署,自动重启,自动复制,自动伸缩/扩展
结构:
二、安装步骤
1.环境要求
一台或多台机器,操作系统 CentOS7.x-86_x64
硬件配置:2GB或更多RAM,2个CPU或更多CPU,硬盘30GB或更多
集群中所有机器之间网络互通
可以访问外网,需要拉取镜像
禁止swap分区
2.安装目标
在所有节点上安装Docker和kubeadm
部署Kubernetes Master
部署容器网络插件
部署 Kubernetes Node,将节点加入Kubernetes集群中
部署Dashboard Web页面,可视化查看Kubernetes资源
3.准备环境
3.1 关闭防火墙
systemctl stop firewalld
systemctl disable firewalld
3.2 关闭selinux
sed -i 's/enforcing/disabled/' /etc/selinux/config
setenforce 0
3.3 关闭swap
swapoff -a # 临时关闭
sed -ri 's/.*swap.*/#&/' /etc/fstab #永久关闭
3.4 修改主机名称
hostnamectl set-hostname 名字
3.5 添加主机名与IP对应关系
cat /etc/hosts
192.168.116.129 master
192.168.116.130 note1
192.168.116.131 note2
3.6 将桥接的IPv4流量传递到iptables的链
cat > /etc/sysctl.d/k8s.conf << EOF
net.bridge.bridge-nf-call-ip6tables = 1
net.bridge.bridge-nf-call-iptables = 1
EOF
4.所有节点安装Docker/kubeadm/kubelet
4.1 安装Docker
curl -fsSL https://get.docker.com | bash -s docker --mirror Aliyun
4.2 开启自启和启动
systemctl enable docker && systemctl start docker
4.3 查看版本
docker --version
4.4 添加阿里云YUM的软件源
cat > /etc/yum.repos.d/kubernetes.repo << EOF
[kubernetes]
name=Kubernetes
baseurl=https://mirrors.aliyun.com/kubernetes/yum/repos/kubernetes-el7-x86_64
enabled=1
gpgcheck=0
repo_gpgcheck=0
gpgkey=https://mirrors.aliyun.com/kubernetes/yum/doc/yum-key.gpg https://mirrors.aliyun.com/kubernetes/yum/doc/rpm-package-key.gpg
EOF
4.5 安装kubeadm,kubelet和kubectl
yum install -y kubelet-1.15.0 kubeadm-1.15.0 kubectl-1.15.0
systemctl enable kubelet
5. 部署Kubernetes Master
kubeadm init \
--apiserver-advertise-address=192.168.116.129 \
--image-repository registry.aliyuncs.com/google_containers \
--kubernetes-version v1.15.0 \
--service-cidr=10.1.0.0/16 \
--pod-network-cidr=10.244.0.0/16
5. 部署Kubernetes Master
5.1 配置
kubeadm init \
--apiserver-advertise-address=192.168.116.129 \
--image-repository registry.aliyuncs.com/google_containers \
--kubernetes-version v1.15.0 \
--service-cidr=10.1.0.0/16 \
--pod-network-cidr=10.244.0.0/16
5.2 使用kubectl工具:
mkdir -p $HOME/.kube
sudo cp -i /etc/kubernetes/admin.conf $HOME/.kube/config
sudo chown $(id -u):$(id -g) $HOME/.kube/config
5.3 安装Pod网络插件(CNI)
kubectl apply -f kube-flannel.yml
6. 加入Kubernetes Node
6.1 在node上安装flannel
docker pull lizhenliang/flannel:v0.11.0-amd64
6.2 向集群添加新节点
kubeadm join 192.168.116.129:6443 --token iz96vy.f5ukew9geeome5is \
--discovery-token-ca-cert-hash sha256:72b689426bfc34512294c29b39ea3b2af3a94e39f62c4434f3a49f16d51a1382
7. 部署 Dashboard
7.1 先Docker拉去镜像
docker pull lizhenliang/kubernetes-dashboard-amd64:v1.10.1
7.2 执行kubernetes-dashboard.yaml 文件
kubectl apply -f kubernetes-dashboard.yaml
7.3 访问 Dashboard的web界面
https://NodeIP:30000
更多推荐
所有评论(0)