当前位置: 首页 > news >正文

缓存管理自动化:JuiceFS 企业版 Cache Group Operator 新特性发布

近期,JuiceFS 企业版推出了 Cache Group Operator,用于自动化创建和管理缓存组集群。Operator 是一种简化 Kubernetes 应用管理的工具,它能够自动化应用程序的生命周期管理任务,使部署、扩展和运维更加高效。

在推出 Operator 之前,我们曾通过 StatefulSet 或 DaemonSet 的方式为用户提供缓存组创建功能,但用户在使用这种方式时存在以下不便之处:

  • 节点配置不灵活:无法在同一集群内针对不同节点类型或资源(如挂载参数、缓存组权重、缓存盘等)进行单独配置;
  • 手动管理节点:需要依赖人工监控并手动添加或移除节点,操作繁琐且易出错;
  • 缓存清理不自动化:缓存清理需手动执行,缺乏自动化支持。

为了解决这些问题,JuiceFS 推出了 Cache Group Operator,提供以下功能:

  • 在同一集群中配置不同的节点类型和资源,满足不同的节点的需求;
  • 支持平滑添加或移除节点,尽可能减小加减节点期间缓存命中率波动;
  • 自动缓存清理;
  • 通过 UI 的形式可视化管理缓存组集群。

01 如何使用 Operator

安装 Operator

首先,添加 JuiceFS Helm 仓库并更新:

helm repo add juicefs https://juicedata.github.io/charts/
helm repo update

使用 Helm 安装 JuiceFS Cache Group Operator:

helm upgrade --install juicefs-cache-group-operator juicefs/juicefs-cache-group-operator -n juicefs-cache-group --create-namespace

用户可以使用 kubectl wait 等待 Operator 准备就绪:

kubectl wait -n juicefs-cache-group --for=condition=Available=true --timeout=120s deployment/juicefs-cache-group-operator

创建缓存组集群

apiVersion: v1
kind: Secret
metadata:name: juicefs-secretnamespace: juicefs-cache-group
type: Opaque
stringData:name: juicefs-xxtoken: xxaccess-key: xxsecret-key: xx
---
apiVersion: juicefs.io/v1
kind: CacheGroup
metadata:name: cachegroup-samplenamespace: juicefs-cache-group
spec:secretRef:name: juicefs-secretworker:template:nodeSelector:juicefs.io/cg-worker: "true"image: juicedata/mount:ee-5.1.1-1faf43bopts:- group-weight=100resources:requests:cpu: 100mmemory: 128Milimits:cpu: 1memory: 1Gi

我们给需要节点添加如下标签,即可添加一个缓存组节点

kubectl label node node1 juicefs.io/cg-worker=true

缓存节点可能存在异构的配置(例如缓存盘的大小不一样),此时可以通过 spec.worker.overwrite 字段来为不同的节点指定不同的配置:

apiVersion: juicefs.io/v1
kind: CacheGroup
metadata:name: cachegroup-sample
spec:worker:template:nodeSelector:juicefs.io/cg-worker: "true"image: juicedata/mount:ee-5.1.1-1faf43bhostNetwork: truecacheDirs:- path: /var/jfsCache-0type: HostPathopts:- group-weight=100# 单位 MiB- cache-size=2048overwrite:- nodes:- k8s-03# 也可以使用 nodeSelector# nodeSelector:#   kubernetes.io/hostname: k8s-02opts:# 单位 MiB- cache-size=1024- group-weight=50cacheDirs:- path: /var/jfsCache-1type: HostPath- path: /var/jfsCache-2type: HostPath

获取缓存组状态

$ kubectl get cachegroupsNAME                CACHE GROUP NAME                        PHASE   READY   AGE
cachegroup-sample   juicefs-cache-group-cachegroup-sample   Ready   1/1     10s

当 phase 状态变为 Ready 时,表示缓存组已成功创建。接下来,用户可以在客户端上添加挂载参数,以开始使用缓存组:

juicefs mount xx -o cache-group=juicefs-cache-group-cachegroup-sample,no-sharing

平滑增删节点

当节点发生变更时,缓存组 Operator 会以平滑的形式增删节点,具体逻辑如下:

  • 当新增节点时,缓存组 Operator 会自动创建新的 Worker Pod,并添加 group-backup 挂载参数。如果新的 Worker Pod 接收到应用请求,并且发现缓存未命中,这个 Worker Pod 会将请求转发给其它缓存节点,确保缓存可以命中。默认 10 分钟后,group-backup 挂载参数会被移除掉,可以通过 spec.backupDuration 来控制默认时间:

    apiVersion: juicefs.io/v1
    kind: CacheGroup
    metadata:name: cachegroup-sample
    spec:backupDuration: 10m
    
  • 当移除节点时,缓存组 Operator 会先尝试将节点上的缓存数据迁移到其它节点,然后再删除节点。最长等待数据迁移时间默认为 1 小时,可以通过 spec.waitingDeletedMaxDuration 来控制默认时间:

    apiVersion: juicefs.io/v1
    kind: CacheGroup
    metadata:name: cachegroup-sample
    spec:waitingDeletedMaxDuration: 1h
    

02 在 CSI Dashboard 中使用

安装完成后,用户可以通过 JuiceFS CSI Dashboard 轻松查看和管理缓存组集群。Dashboard 提供了直观的界面,帮助实时监控缓存组的运行状态,灵活添加或移除缓存节点,并详细查看缓存的使用情况。

通过 Dashboard 管理缓存组集群

  1. 添加/移除缓存节点

2.查看缓存使用情况

3.预热缓存组集群

通过点击添加节点的旁边的「预热」按钮对缓存组进行预热。你可以通过调整下面的参数来实现自定义的目的,例如默认会对整个文件系统进行预热,可以调整 subpath 对指定目录进行预热。

有关 JuiceFS Cache Group Operator 的更多详细信息,请参考官方文档:

JuiceFS Cache Group Operator 文档

http://www.lryc.cn/news/511317.html

相关文章:

  • C++ 并发专题 - 实现一个线程安全的队列
  • SQL 基础教程
  • 【源码】Sharding-JDBC源码分析之SQL中影子库ShadowSQLRouter路由的原理
  • 雷池 WAF 搭配阿里云 CDN 使用教程
  • 3.银河麒麟V10 离线安装Nginx
  • 【模块一】kubernetes容器编排进阶实战之kubernetes 资源限制
  • 【开源】一款基于SpringBoot的智慧小区物业管理系统
  • Goland:专为Go语言设计的高效IDE
  • 云手机与Temu矩阵:跨境电商运营新引擎
  • 仓颉编程笔记1:变量函数定义,常用关键字,实际编写示例
  • Python小括号( )、中括号[ ]和大括号{}代表什么
  • React里使用lodash工具库
  • 【免费分享】mysql笔记,涵盖查询、缓存、存储过程、索引,优化。
  • C语言-数据结构-图
  • android sqlite 数据库简单封装示例(java)
  • “宠物服务的跨平台整合”:多设备宠物服务平台的实现
  • 关于最新MySQL9.0.1版本zip自配(通用)版下载、安装、环境配置
  • 【Halcon】例程讲解:基于形状匹配与OCR的多图像处理(附图像、程序下载链接)
  • B站推荐模型数据流的一致性架构
  • 不安全物联网的轻量级加密:综述
  • mysql_init的概念和使用案例
  • 3GPP R18 MT-SDT
  • 时频转换 | Matlab暂态提取变换transient-extracting transform一维数据转二维图像方法
  • .NET Framework 逐渐过时,.NET 8和 .NET 9引领未来
  • 从虚拟到现实:AI与AR/VR技术如何改变体验经济?
  • 在K8S中,Ingress该如何使用?
  • Ubuntu24.04安装NVIDIA驱动及工具包
  • 【每日学点鸿蒙知识】组件封装通用方法、callback和await性能对比、Web组件下拉刷新、hsp包报错、WebView圆角
  • Excel批量设置行高,Excel表格设置自动换行后打印显示不全,Excel表格设置最合适的行高后打印显示不全,完美解决方案!!!
  • Web Bluetooth API 开发记录