品牌购物网站十大排名,html怎么做网页框架,高手做网站,代码改wordpress地址简介#xff1a; 为了解决大数据、AI 等数据密集型应用在云原生场景下#xff0c;面临的异构数据源访问复杂、存算分离 I/O 速度慢、场景感知弱调度低效等痛点问题#xff0c;南京大学PASALab、阿里巴巴、Alluxio 在 2020 年 6 月份联合发起了开源项目 Fluid。 作者 | 顾荣 …简介 为了解决大数据、AI 等数据密集型应用在云原生场景下面临的异构数据源访问复杂、存算分离 I/O 速度慢、场景感知弱调度低效等痛点问题南京大学PASALab、阿里巴巴、Alluxio 在 2020 年 6 月份联合发起了开源项目 Fluid。 作者 | 顾荣 南京大学PASALab, Fluid项目co-founder 来源 | 阿里巴巴云原生公众号
导读为了解决大数据、AI 等数据密集型应用在云原生场景下面临的异构数据源访问复杂、存算分离 I/O 速度慢、场景感知弱调度低效等痛点问题南京大学PASALab、阿里巴巴、Alluxio 在 2020 年 6 月份联合发起了开源项目 Fluid。Fluid 是云原生环境下数据密集型应用的高效支撑平台项目自开源发布以来吸引了众多相关方向领域专家和工程师的关注在大家的积极反馈下社区不断演进。近期 Fluid 0.5 版本正式发布在该版本中Fluid 主要新增改善以下三个方面内容
丰富数据集的操作功能支持在线弹性扩缩容、元数据备份和恢复。支持多样环境配置部署满足用户的个性化部署配置需求。新增数据缓存引擎实现增加用户在公有云上的引擎选择。
Fluid 开源项目地址https://github.com/fluid-cloudnative/fluid
这三大主要功能的开发需求来自众多社区用户的实际生产反馈此外 Fluid v0.5 还进行了一些 bug 修复和文档更新欢迎使用体验 Fluid v0.5
Fluidv0.5 下载链接https://github.com/fluid-cloudnative/fluid/releases
下文是本次新版本发布功能的进一步介绍。
丰富数据集的操作功能
在本版本中 Fluid 重点丰富了核心抽象对象 —— Dataset数据集的相关操作功能从而使数据密集型应用能够更好地利用云原生提供的弹性、可观测性等基础功能并增强了用户对数据集管理的灵活性。
1. 数据集在线弹性缓存扩缩容
这是社区用户一直期待的功能在 Fluid v0.5 之前如果用户想要调整数据集的缓存能力需要以全部卸载缓存引擎再重部署的方式完成。这种方式耗时耗力还必须考虑数据缓存全部丢失的高昂代价。因此在新版本中我们为数据集提供了对缓存弹性扩缩容的支持用户可以根据自己的场景需求以不停机方式 on-the-fly 地按需增加某数据集的缓存容量以加速数据访问扩容或减少某个不频繁使用的数据集的缓存容量缩容从而实现更加精细的弹性资源分配提高资源利用率。Fluid 内置的控制器会根据策略选择合适的扩缩容节点例如在缩容时会结合节点上运行任务情况和节点缓存比例作为筛选条件。
执行弹性数据集的缓存能力弹性扩缩容用户只需运行如下命令
kubectl scale alluxioruntimes.data.fluid.io {datasetName} --replicas{num}
其中 datasetName 对应于数据集的名称replicas 指定缓存节点的数目。
有关数据集手动扩缩容及其效果的演示视频http://cloud.video.taobao.com/play/u/2987821887/p/1/e/6/t/1/302459823704.mp4
更多关于数据集手动扩缩容的操作细节请参考 Github 上的示例文档。
2. 元数据的备份与恢复
该功能增强了 Fluid 数据集元数据管理的灵活性。先前的 Fluid v0.4 已经支持将数据集的元数据例如文件系统 inode tree加载至本地并且会记录数据集的一些关键统计信息例如数据量大小和文件数量。然而一旦用户销毁本地数据集这些元数据信息也都将丢失重新构建数据集时需再次从底层存储系统获取。
因此在 Fluid v0.5 中我们新增了一个 K8s 自定义资源对象 —— DataBackup为用户提供了声明式的 API 接口以控制数据备份的相关行为。DataBackup 自定义资源对象构建的一个简单示例如下所示
apiVersion: data.fluid.io/v1alpha1
kind: DataBackup
metadata:name: hbase-backup
spec:dataset: hbasebackupPath: pvc://pvcName/subpath1/subpath2/
再次创建数据集时只需新增一个指定备份文件位置的字段
apiVersion: data.fluid.io/v1alpha1
kind: Dataset
metadata:name: hbase
spec:dataRestoreLocation:path: pvc://pvc-local/subpath1/mounts:- mountPoint: https://mirrors.tuna.tsinghua.edu.cn/apache/hbase/2.2.6/
此时Fluid 将首先从备份文件加载元数据和数据集统计信息从而很大地提高元数据加载速度。 更多关于进行数据集元数据备份与恢复的操作细节请参考 Github 上的示例文档。
3. 数据集的可观测性优化
Fluid v0.5 还进一步增强了数据集的可观测性能力具体包括两个部分
1与 Prometheus 相结合
该特性能够支持数据集的可用性和性能指标收集并且通过 Grafana 进行可视化展示。目前已支持 AlluxioRuntime 的实现使用者可以方便地了解当前可缓存节点、缓存空间、现有缓存比例、远程读、短路读等性能指标。整个配置过程非常简单达到了对于数据集监控系统“开箱即用的效果。
具体的使用方法请参考 Github 上的示例文档。
2新增数据集缓存命中率指标
该功能可以标识过去 1 分钟内对该数据集的全部访问中有多少访问命中了分布式缓存。该指标一方面能够帮助用户分析他们数据密集型应用中的性能瓶颈量化查看 Fluid 在整个应用运行的工作流中起到的效果另一方面能够帮助用户在应用性能提升和缓存资源占用间进行行权衡做出合理的扩缩容决策。
这一指标被添加在 Fuild v0.5 的 Dataset.Status.CacheStates 的 Dataset CRD 资源状态中具体来说包括
Cache Hit Ratio过去一分钟分布式缓存命中的访问百分比。Local Hit Ratio过去一分钟本地缓存命中的访问百分比。Remote Hit Ratio过去一分钟远程缓存命中的访问百分比。
注: 对于分布式缓存而言数据命中有两种不同的缓存命中情况。本地缓存命中指的是访问发起者可直接在同结点访问到缓存数据。远程缓存命中指的是访问发起者需要通过网络访问其他结点上的缓存数据。在 Fluid v0.5 中用户可以使用以下命令方便地查看缓存命中率指标
kubectl get dataset dataset-name -o wide
NAME ... CACHE HIT RATIO AGE
dataset-name ... 86.2% 16m
支持多样环境配置部署
自 Fluid 0.4 版本发布以来我们根据社区用户实际部署反馈的问题和需求对 Fluid 在多样环境下的部署配置增加了更多支持。
1. 支持 Fuse 的 global 模式
在 Fluid 中Dataset 资源对象中所定义的远程文件是可被调度的这意味着你能够像管理 Pod 一样管理远程文件缓存到 Kubernetes 集群上的位置。执行计算的 Pod 可以通过 Fuse 客户端访问数据文件。在先前版本的 Fluid 中Fuse 客户端总是会调度到缓存所在的节点上但是用户不能自由控制 Fuse 的调度。
在 Fluid v0.5 中我们为 Fuse 新增了 global 部署模式。在该模式下Fuse 默认会全局部署到所有节点上。用户也可以通过指定 Fuse 的 nodeSelector 来影响 Fuse 的调度结果。同时缓存会优先调度部署在执行计算 Pod 数量较多的节点上。
具体使用非常简单可以参考 Github 上的示例文档。
2. 支持 HDFS 的用户级配置
很多社区用户使用分布式缓存系统 Alluxio 作为 Fluid 数据集的缓存引擎。在数据集持久化存储于 HDFS 文件系统的情况下要使得 Alluxio 能够正常访问底层 HDFSAlluxio 集群需要提前获取该 HDFS 的各类配置信息。
在 Fluid v0.5 中我们使用 Kubernetes 的原生资源为上述场景提供支持。用户首先需要将 HDFS 的相关配置文件e.g. hdfs-site.xml 和 core-site.xml以 ConfigMap 方式创建到 Kubernetes 环境中接着在创建的 AlluxioRuntime 资源对象中引用上述创建的 ConfigMap 从而实现上述功能。
AlluxioRuntime 资源对象的一个示例如下所示
apiVersion: data.fluid.io/v1alpha1
kind: AlluxioRuntime
metadata:name: my-hdfs
spec:...hadoopConfig: configmap-name...
至此创建出的 Alluxio 集群将能够正常地访问 HDFS 集群中的数据。更多内容可参考 Github 上的示例文档。
新增数据缓存引擎实现
Fluid 默认使用的分布式缓存 Runtime 是 AlluxioRuntime为了支持不同环境用户对缓存系统的需求在之前的版本中 Fluid 已经将分布式缓存 Runtime 接入框架做成了可插拔的架构。在 Fluid v0.5 中来自阿里云的社区贡献者基于该框架开发了 JindoRuntime新增了一种支撑 Fluid Dataset 数据管理和缓存的执行引擎实现。用户可以在 Fluid 中通过 JindoRuntime 使用 JindoFS 的 Cache 模式进行远端文件的访问和缓存。在 Fluid 上使用和部署 JindoRuntime 流程简单、兼容原生 K8s 环境、开箱即用。
总结
在 Fluid v0.5 中我们对 Fluid 的功能特性与用户体验都进行了丰富和增强。
首先Fluid v0.5 进一步增加了数据集的功能操作
提供数据集在线弹性扩缩容能力实现更灵活、更精细的集群资源分配控制。新增 DataBackup CRD实现了数据集文件元数据等信息的备份与恢复帮助完成数据集缓存系统的快速重启。新增缓存命中率指标帮助用户更好量化分析 Fluid 提供的加速效果。
其次Fluid 支持更多环境模式和配置满足更多真实场景的部署需求。
最后Fluid 新增了基于 JindoFS 的分布式缓存 Runtime —— JindoRuntime为用户在多样化部署环境中提供不同的缓存引擎选择。 鸣谢
感谢为此版本做出贡献的社区小伙伴们他们包括来自阿里云的王涛、腾讯云的谢远东、中国电信的仇伶玮、南京大学 PASALab 的徐之浩、候浩军、陈国旺、陈雨铨等同学。
作者简介
顾荣 博士南京大学计算机系副研究员Fluid 开源项目 co-founder、Alluxio 开源项目 PMC 成员研究方向大数据处理系统已在 TPDS、ICDE、JPDC、IPDPS、ICPP 等领域前沿期刊会议发表论文30余篇主持国家自然科学基金面上项目/青年项目、中国博士后科学基金特别资助项目多项研究成果落地应用于阿里巴巴、百度、字节跳动、中国石化、华泰证券等公司和开源项目 Apache Spark、Alluxio获 2018 年度江苏省科学技术一等奖、2019 年度江苏省计算机学会青年科技奖担任中国计算机学会系统软件专委会委员/大数据专委会通讯委员、江苏省计算机学会大数据专委会秘书长。
原文链接
本文为阿里云原创内容未经允许不得转载。