Kubernetes(k8s)安装NFS动态供给存储类并安装KubeSphere

Kubernetes安装NFS动态供给存储类并安装KubeSphere

KubeSphere介绍

它是一款全栈的 Kubernetes 容器云 PaaS 解决方案(来源于官网),而我觉得它是一款强大的Kubernetes图形界面,它继承了如下组件 (下面这段内容来自官网):

  • Kubernetes DevOps 系统
    • 基于 Jenkins 为引擎打造的 CI/CD,内置 Source-to-Image 和 Binary-to-Image 自动化打包部署工具
  • 基于 Istio 的微服务治理
    • 提供细粒度的流量管理、流量监控、灰度发布、分布式追踪,支持可视化的流量拓扑
  • 丰富的云原生可观测性
    • 提供多维度与多租户的监控、日志、事件、审计搜索,支持多种告警策略与通知渠道,支持日志转发
  • 云原生应用商店
    • 提供基于 Helm 的应用商店与应用仓库,内置多个应用模板,支持应用生命周期管理
  • Kubernetes 多集群管理
    • 跨多云与多集群统一分发应用,提供集群高可用与灾备的最佳实践,支持跨级群的可观测性
  • Kubernetes 边缘节点管理
    • 基于 KubeEdge 实现应用与工作负载在云端与边缘节点的统一分发与管理,解决在海量边、端设备上完成应用交付、运维、管控的需求

当然他的功能远不止这些,欢迎各位来到KubeSphere的官网了解更多内容:https://www.kubesphere.io/zh/

环境准备

KubeSphere

(摘自官网)

  • 您的 Kubernetes 版本必须为:v1.20.x、v1.21.x、* v1.22.x、* v1.23.x、* v1.24.x、* v1.25.x 和 * v1.26.x。带星号的版本可能出现边缘节点部分功能不可用的情况。因此,如需使用边缘节点,推荐安装 v1.21.x。
  • 确保您的机器满足最低硬件要求:CPU > 1 核,内存 > 2 GB。
  • 在安装之前,需要配置 Kubernetes 集群中的默认存储类型(这篇文章会介绍安装)。

我已经准备好了一个Kubernetes集群,如图:

符合KubeSphere的支持边缘节点的最高版本要求,但建议你版本号不要超过 v1.26.x

NFS动态供给

首先你需要准备一台NFS服务器,为了方便,我这次就以我的主服务器 k8s-master 来担任这个NFS服务器了。

安装NFS动态供给

搭建NFS

首先我们需要在NFS服务器(我的NFS服务器和master是同一台)和所有k8s节点当中安装 nfs-utils 软件包(master和node都需要安装),可执行下面这行命令:

bash 复制代码
yum install -y nfs-utils

安装如图:

然后确定一个nfs共享的目录,这次我就使用 /data/nfs/dynamic-provisioner 这个目录作为nfs的共享目录了。所以我们来执行下面命令创建并共享这个目录:

bash 复制代码
# 创建这个目录
mkdir -p /data/nfs/dynamic-provisioner
# 执行这行命令将这个目录写到写到 /etc/exports 文件当中去,这样NFS会对局域网暴露这个目录
cat >> /etc/exports << EOF
/data/nfs/dynamic-provisioner *(rw,sync,no_root_squash)
EOF
# 启动NFS服务
systemctl enable --now nfs-server

执行后如图:

检查是否暴露成功:

bash 复制代码
showmount -e {nfs服务器地址}

可以看到是暴露成功的:

下载动态供给驱动

因为Kubernetes自己不自带NFS动态供给的驱动,所以我们需要下载第三方的NFS动态供给驱动。Kubernetes官方推荐了两个第三方的驱动可供选择,如图:

个人觉得这个 NFS subdir 驱动比较好用,这次就用这个驱动来搭建动态供给了。我们可以来到它的官网:https://github.com/kubernetes-sigs/nfs-subdir-external-provisioner,并找到最新的release:

目前最新的发行版是 4.0.18 我们就下载这个版本:

也可直接通过命令下载:

bash 复制代码
wget https://github.com/kubernetes-sigs/nfs-subdir-external-provisioner/archive/refs/tags/nfs-subdir-external-provisioner-4.0.18.tar.gz

下载成功如图:

我们直接解压它:

bash 复制代码
tar -zxvf nfs-subdir-external-provisioner-4.0.18.tar.gz

解压之后会获得一个特别长的文件夹:

修改驱动文件

我们来到这个文件夹下的deploy目录:

bash 复制代码
cd nfs-subdir-external-provisioner-nfs-subdir-external-provisioner-4.0.18/deploy/

可以看到这里面有一些yaml,我们需要修改一部分:

首先我们需要修改的就是 deployment.yaml ,我们直接用vim修改:

bash 复制代码
vim deployment.yaml

首先就是这个镜像是在谷歌的k8s官方镜像仓库拉取的,国内拉取不到,所以我们要修改一下:

我已经通过一些方法将它拉取下来并且上传到了国内的阿里云镜像仓库,我们可以直接用下面这个镜像来替换:

yaml 复制代码
# 这个镜像是在谷歌上的,国内拉取不到
# image: registry.k8s.io/sig-storage/nfs-subdir-external-provisioner:v4.0.2
# 使用这个我先在谷歌上拉取下来再上传到阿里云上的镜像
image: registry.cn-shenzhen.aliyuncs.com/xiaohh-docker/nfs-subdir-external-provisioner:v4.0.2

修改后如图:

然后我们还需要修改一下下面的nfs服务器地址和nfs服务器内共享的目录:

我的nfs服务器地址为 172.18.0.2 ,且按照上面的安装步骤,我nfs服务器暴露的共享目录为 /data/nfs/dynamic-provisioner ,所以我修改文件为(你的有可能和我不一样,根据自己设置的共享目录和nfs服务器地址修改此文件):

执行下面这一段脚本我们可以看到还是有很多资源是存放在默认命名空间下:

bash 复制代码
yamls=$(grep -rl 'namespace: default' ./)
for yaml in ${yamls}; do
  echo ${yaml}
  cat ${yaml} | grep 'namespace: default'
done

执行结果:

我们可以新创建一个命名空间专门装这个驱动,也方便以后管理,所以我决定创建一个名为 nfs-provisioner 命名空间,为了方便就不用yaml文件了,直接通过命令创建:

bash 复制代码
kubectl create namespace nfs-provisioner

执行后可以看到这个命名空间创建成功:

涉及命名空间这个配置的文件还挺多的,所以我们干脆通过一行脚本更改所有:

bash 复制代码
sed -i 's/namespace: default/namespace: nfs-provisioner/g' `grep -rl 'namespace: default' ./`

这行批量替换脚本直接将所有文件的命名空间都改过来了:

安装动态供给

之前我们已经修改好了所有的yaml资源清单文件,接下来我们直接执行安装。安装也是非常简单,直接通过下面一行命令就可以安装完成:

bash 复制代码
kubectl apply -k .

执行结果如图:

可以执行下面这个行命令查看是否部署完成:

bash 复制代码
kubectl get all -o wide -n nfs-provisioner

看到READY为 1/1 并且STATUS状态为 Running 那么动态供给就已经部署完毕:

可以执行下面命令查询安装的动态供应存储类的名字:

bash 复制代码
kubectl get storageclass

可以看到动态供应类的名字为 nfs-client

nfs动态供应就已经安装完毕了

如果你只打算安装动态供给的存储类,那么到这里就结束了哦,接下来是KubeSphere相关的内容

安装KubeSphere

下载KubeSphere的yaml资源清单文件

此次安装的是最新的 v3.4.0 的 KubeSphere,可以通过以下命令下载资源清单文件(共两个):

bash 复制代码
wget \
https://github.com/kubesphere/ks-installer/releases/download/v3.4.0/kubesphere-installer.yaml \
https://github.com/kubesphere/ks-installer/releases/download/v3.4.0/cluster-configuration.yaml

可以看到一共下载了两个文件:

其中这两个文件的作用:

  • kubesphere-installer.yaml: KubeSphere的安装器
  • cluster-configuration.yaml: KubeSphere的集群配置文件

我们需要修改一下 cluster-configuration.yaml 文件,还记得我们之前的那个存储类吗?我们记住这个名字:

然后我们开始修改这个文件:

bash 复制代码
vim cluster-configuration.yaml

可以看到后面注释的说明,所以我们将 nfs-client 这个存储类的名字写在后面:

安装KubeSphere

然后我们先创建 kubesphere-installer.yaml 里面的资源:

bash 复制代码
kubectl apply -f kubesphere-installer.yaml

可以看到创建了一些资源:

然后我们检查这个资源是否创建成功:

bash 复制代码
kubectl get pod -o wide -n kubesphere-system

同样当READY为 1/1 并且STATUS状态为 Running 的时候这个文件就执行完毕了:

接下来我们来执行 cluster-configuration.yaml 文件:

bash 复制代码
kubectl apply -f cluster-configuration.yaml

它虽然只有一个资源,但是里面还是要做很多事的:

执行下面命令检查KubeSphere的执行日志:

bash 复制代码
kubectl logs -n kubesphere-system $(kubectl get pod -n kubesphere-system -l 'app in (ks-install, ks-installer)' -o jsonpath='{.items[0].metadata.name}') -f

一段时间之后看到这个就是安装成功了:

因为我使用的是云服务器,所以我使用任何一个云服务器的公网IP地址+端口就能访问KubeSphere了,默认的用户名/密码是 admin/P@88w0rd

初次登陆需要修改admin用户的密码:

随后即可以登录到KubeSphere的首页了:

同时我们来到NFS服务器共享的目录,可以看到KubeSphere的持久化数据存储在这:

使用KubeSphere部署应用

创建项目

因为KubeSphere的管理是基于项目的,所以我们先要创建一个项目,先点击企业空间:

选择这个默认企业(一般是新建一个企业,这里就简化了):

然后点击项目->创建:

创建一个测试项目:

创建一个项目其实就是创建了一个命名空间:

部署MySQL

现在我们开始部署MySQL了,点击这个刚创建的项目:

然后依次点击 工作负载->有状态副本集->创建

填写部署一个测试的数据库然后点击下一步:

点击添加容器:

搜索指定的镜像并填写要创建的容器名字:

网下面拉可以设置CPU和内存限制还有需要使用的端口:

然后我们往下拉勾选环境变量,然后点击创建保密字典:

我们来设置mysql的密码,这个名字可以随便写,但是自己要记住:

类型选择默认后点击添加数据:

在这里设置mysql的root用户密码:

然后点击创建:

最后创建的Secret会自动填充,但是注意MySQL设置root用户密码的环境变量名不能自定义,是由Docker规定死的 MYSQL_ROOT_PASSWORD

点击勾选同步主机时区:

点击下面的对勾✅:

最后点击下一步:

到了下一步点击添加持久卷声明模版:

然后按照提示输入内容:

最后点击下一步:

点击创建:

点击部署的这个mysql进来:

可以看到容器状态并且可以快速伸缩容器:

当这个变绿了就代表创建好了:

然后点击容器右边的向下的小箭头,最后点击终端:

最后在终端中即可运行mysql相关的命令了:

这篇文章就先写到这里,更多的KubeSphere操作,可以登录KubeSphere的官网了解,关注我,我以后一会写更多相关知识的哦!

KubeSphere官网:https://www.kubesphere.io/zh/

相关推荐
ZHOU西口29 分钟前
微服务实战系列之玩转Docker(十八)
分布式·docker·云原生·架构·数据安全·etcd·rbac
牛角上的男孩1 小时前
Istio Gateway发布服务
云原生·gateway·istio
JuiceFS2 小时前
好未来:多云环境下基于 JuiceFS 建设低运维模型仓库
运维·云原生
景天科技苑3 小时前
【云原生开发】K8S多集群资源管理平台架构设计
云原生·容器·kubernetes·k8s·云原生开发·k8s管理系统
wclass-zhengge4 小时前
K8S篇(基本介绍)
云原生·容器·kubernetes
颜淡慕潇4 小时前
【K8S问题系列 |1 】Kubernetes 中 NodePort 类型的 Service 无法访问【已解决】
后端·云原生·容器·kubernetes·问题解决
川石课堂软件测试6 小时前
性能测试|docker容器下搭建JMeter+Grafana+Influxdb监控可视化平台
运维·javascript·深度学习·jmeter·docker·容器·grafana
昌sit!12 小时前
K8S node节点没有相应的pod镜像运行故障处理办法
云原生·容器·kubernetes
A ?Charis15 小时前
Gitlab-runner running on Kubernetes - hostAliases
容器·kubernetes·gitlab
wclass-zhengge15 小时前
Docker篇(Docker Compose)
运维·docker·容器