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

Apache Hop实战:Windows平台MySL数据迁移的深度排错与性能调优

AI训练存储选型的演进路线第一阶段单机直连时代早期的深度学习数据集较小模型训练通常在单台服务器或单张GPU卡上完成。此时直接将数据存储在训练机器的本地NVMe SSD/HDD上。其优势在于IO延迟最低吞吐量极高也就是“数据离计算最近”。缺点也很明显数据孤岛多台机器无法共享数据数据拷贝scp/rsync)及其耗时。容量受限本地磁盘容量有限。数据安全数据没有冗余机器或盘挂了数据可能就丢了。第二阶段传统共享存储时代NFS/NAS到后来开始团队协作训练规模也变大则需要多机多卡分布式训练同时出于使用方便大家希望像操作本地文件一样操作共享数据。此时开始以NFSNetwork File System)挂载传统的NAS存储阵列来使用。其优势在于POSIX兼容不需要修改PyTorch/TensorFlow代码直接读写文件路径共享也十分便利所有节点看到的目录结构一致。缺点则在于元数据性能瓶颈NFS在处理海量小文件的open,lookup操作时元数据服务器可能被瞬间打死。另外所有计算节点抢占同一个NAS的出口带宽也可能导致GPU等待IO造成GPU无法维持高使用率。第三阶段大数据融合时代HDFSGoogle等大厂入局Hadoop诞生。数据存储在HDFS上通过一些软件层面的优化将大量小图片打包成大文件变成“顺序读”训练代码通过API读取。这样就能够极大地利用HDFS的设计初衷吞吐量极高、大规模顺序读同时还能利用现成的大数据基础设施。但同样有缺点生态割裂PyTorch对HDFS支持不如TensorFlow友好。随机访问差对于需要频繁Shuffle(随机打乱)的数据集HDFS性能不佳。Java开销HDFS客户端通常较重占用CPU资源第四阶段高性能并行文件系统HPC/Parallel FS)此时的AI领域进入超算时代模型越来越大对低延迟和超高带宽的要求极高。此时的方案是借用超算HPC领域的Lustre或GPFSIMB Spectrum Scale)。优点在于专为高并发设计可以轻松喂饱数千张GPU支持POSIX且元数据性能极强。缺点则在于贵运维难Lustre等系统内合级调优十分困难一旦集群崩溃恢复十分困难扩容困难很难像云存储那样弹性伸缩。第五阶段存算分离与分层架构Object Storage Cache)当前这个时代即云原生时代数据集达到PB级别成本成为了核心考量。对象存储最便宜且容量无限但性能尤其是元数据不够好。 此时针对元数据有了若干解决方案方案一 原生对象存储格式优化这种方案将数据存储在S3客户端使用S3 SDK进行对接以对象存储的接口访问文件。同时降低小文件数量对小文件进行打包。此处的缺点则在于丧失了POSIX标准。方案二对象存储高性能文件网关这是目前的最终形态也是本文将要讲的形态。其底层数据存储在对象存储中S3、COS、OSS、ceph在用户和对象存储层中加一个中间层作为文件系统层负责将文件系统与对象存储的操作进行翻译转换从而实现POSIX兼容。而最重要的是在GPU训练节点的本地NVMe SSD上建立热数据缓存以提升IO能力。此时第一次读取时从对象存储拉取数据过程稍慢而后续的读取则可以直接走本地缓存极快。而一些实现如JuiceFS)将元数据独立放在Redis/TiKV中可以完美地解决对象存储list对象的性能问题。据最新的企业版JuiceFS文档说明当前单机文件系统已经可以支持5000亿级别文件本文将以“对象存储高性能文件网关”的技术路线的现状进行分析描述业界若干实现的设计思想抛砖引玉。Object Storage Cache的一般性设计原则本小节介绍Object Storage Cache的一般性设计原则。在介绍之前首先需要理清楚文件系统与对象存储的区别是什么文件系统对接对象存储需要做哪些工作之后才考虑性能的优化与可靠性的优化。文件系统与对象存储的异同点分析文件系统的核心特征如下所示层级结构数据以目录树的形式组织文件包含在目录中目录又包含在父目录中。寻址方式通过路径名来访问。数据可变性支持原地修改。应用程序可以打开一个文件seek到特定偏移量然后只修改文件中间的几个字节而无需重写整个文件。操作接口基于系统调用如open(), read(), write(), seek(), close(), flock()等。元数据如权限、创建时间、大小与文件数据紧密绑定通常存储在inode中。强一致性在单机文件系统中写入数据后随后的读取操作立即能看到新数据。原子性许多元数据操作如rename通常是原子的。对象存储的核心特征如下所示扁平结构数据存储在“桶“中没有真正的文件夹或目录层级。虽然看起来像目录但这只是对象键名key)中的前缀字符串。寻址方式通过key访问需要结合对象存储访问域名/IP来访问。数据不可变性对象通常被视为原子单元。无法修改对象的中间部分。如果要修改部分数据必须新上传一个对象来覆盖旧对象Read-Modify-Write。操作接口基于RESTful API()主要操作是PUT上传/覆盖GET下载DELETE删除HEAD获取元数据不支持seek或部分写入。一致性模型不同的对象存储实现下有不同的一致性模型。可能是强一致性如ceph也可能是最终一致性。整理如下表所示image将对象存储S3 协议等挂载为本地文件系统FUSE是业界的常见需求目的是为了让不支持 S3 API 的传统应用也能利用对象存储的低成本和无限容量。由于我们在上一部分分析了“文件系统”与“对象存储”存在巨大的语义鸿沟因此这些 FUSE 工具的核心设计难点都在于如何用笨重的 对象接口去模拟灵活的 POSIX 文件接口。业界主流有两个设计流派直接映射型1:1 Mapping文件对应对象元数据存放在对象头中。元数据分离型Metadata Separation数据存在对象存储元数据存放在独立的数据库中。对象存储的 FUSE 并不是完美的。直接映射型保留了数据的通用性但牺牲了性能和语义元数据分离型重建了文件系统语义和性能但把对象存储降级为了纯粹的“硬盘”牺牲了数据的通用访问性。设计优劣势分析1. 直接映射型 (S3FS, Goofys, Rclone)设计优点通用性强 写入的数据就是标准的 S3 对象。你用 S3FS 传上去的图片可以直接用浏览器通过 S3 URL 打开也可以被其他不使用 FUSE 的程序处理。部署简单 无需额外部署数据库只要有 S3 账号就能用。无状态 客户端挂了重启即可不依赖外部元数据服务。设计劣势元数据性能灾难 S3 处理元数据非常慢。执行 ls -l 可能会很慢还可能造成集群slow op。重命名原子性缺失 在 S3 中没有“重命名目录”的操作。重命名一个包含 1000 个文件的目录S3FS 需要执行 1000 次 Copy 1000 次 Delete。这不仅慢而且如果在中间崩溃目录会断裂一半在旧名一半在新名。无法支持随机写/追加写 修改 1GB 文件的最后 1 个字节S3FS 必须下载 1GB - 修改 - 上传 1GB。效率极低。2. 元数据分离型 (JuiceFS)设计优点极致性能 元数据操作ls, getattr, rename都在 Redis/SQL 中完成延迟是微秒级与本地文件系统无异。完全 POSIX 兼容 通过将文件切块Chunking实现了对象存储本身不支持的“随机写”和“追加写”只用重传修改过的那个 Block。原子性保障 重命名目录只是数据库里的一个事务瞬间完成且原子。缓存能力 通常带有强大的本地缓存机制利用本地磁盘缓存 S3 的数据块。设计劣势数据不透明黑盒 你在 S3 Bucket 里看到的不再是 photo.jpg而是 chunks/1/123_456 这样的分块数据。脱离了 JuiceFS 客户端你无法直接识别和使用 S3 里的数据。运维复杂度 需要额外部署和维护一个高可用的元数据引擎如 Redis 集群或 RDS。腋油故当

相关文章:

Apache Hop实战:Windows平台MySL数据迁移的深度排错与性能调优

AI训练存储选型的演进路线 第一阶段:单机直连时代 早期的深度学习数据集较小,模型训练通常在单台服务器或单张GPU卡上完成。此时直接将数据存储在训练机器的本地NVMe SSD/HDD上。 其优势在于IO延迟最低,吞吐量极高,也就是“数据离…...

如何高效使用PostCSS Input:源文件信息与位置跟踪完整指南

如何高效使用PostCSS Input:源文件信息与位置跟踪完整指南 【免费下载链接】postcss Transforming styles with JS plugins 项目地址: https://gitcode.com/gh_mirrors/po/postcss PostCSS作为一款强大的CSS转换工具,其Input模块在处理源文件信息…...

如何快速掌握Python XML处理技术:从入门到精通的完整指南

如何快速掌握Python XML处理技术:从入门到精通的完整指南 【免费下载链接】python-guide Python best practices guidebook, written for humans. 项目地址: https://gitcode.com/gh_mirrors/py/python-guide GitHub 加速计划的 py/python-guide 项目是一份…...

net-speeder快速入门:5分钟安装配置网络加速神器

net-speeder快速入门:5分钟安装配置网络加速神器 【免费下载链接】net-speeder net-speeder 在高延迟不稳定链路上优化单线程下载速度 项目地址: https://gitcode.com/gh_mirrors/ne/net-speeder net-speeder是一款在高延迟不稳定链路上优化单线程下载速度的…...

如何使用Yew构建高性能实时通信Web应用:WebSocket完全指南

如何使用Yew构建高性能实时通信Web应用:WebSocket完全指南 【免费下载链接】yew Rust / Wasm framework for creating reliable and efficient web applications 项目地址: https://gitcode.com/gh_mirrors/ye/yew Yew是一个基于Rust和WebAssembly的现代Web框…...

Deepnote:云端原生协作笔记本如何重塑数据科学工作流

1. 项目概述:一个为数据科学家量身定制的云端协作笔记本 如果你和我一样,常年和数据、代码、模型打交道,那你一定对Jupyter Notebook又爱又恨。爱它的交互式探索能力,恨它在团队协作、环境管理、版本控制上的种种不便。每次想和同…...

Python统计假设检验17种方法速查与应用指南

## 1. 统计假设检验的核心价值与应用场景统计假设检验是数据分析师和研究人员最常使用的工具之一。在Python生态中,借助SciPy、StatsModels等库,我们可以快速实现各类检验方法。实际工作中经常遇到这样的场景:产品经理拿着AB测试数据问你&quo…...

超轻量歌声转换终极指南:Tiny配置参数调优与性能平衡策略

超轻量歌声转换终极指南:Tiny配置参数调优与性能平衡策略 【免费下载链接】so-vits-svc SoftVC VITS Singing Voice Conversion 项目地址: https://gitcode.com/gh_mirrors/so/so-vits-svc SoftVC VITS Singing Voice Conversion(so-vits-svc&…...

深度学习显存优化:混合精度与梯度检查点实战

1. 内存受限场景下的模型训练挑战在深度学习模型规模爆炸式增长的今天,我们经常遇到显存不足的困境。当尝试在消费级显卡(如RTX 3090的24GB显存)上训练参数量超过1亿的模型时,常规训练方法很快就会耗尽显存资源。这就像试图用家用…...

XState游戏开发终极指南:如何用状态机设计复杂游戏逻辑

XState游戏开发终极指南:如何用状态机设计复杂游戏逻辑 【免费下载链接】xstate State machines, statecharts, and actors for complex logic 项目地址: https://gitcode.com/gh_mirrors/xs/xstate 游戏开发中,复杂的逻辑状态管理常常让开发者头…...

如何快速掌握Type Challenges中的数组最后一个元素类型提取技巧

如何快速掌握Type Challenges中的数组最后一个元素类型提取技巧 【免费下载链接】type-challenges Collection of TypeScript type challenges with online judge 项目地址: https://gitcode.com/GitHub_Trending/ty/type-challenges Type Challenges是一个专注于TypeSc…...

如何快速搭建Foundation Sites本地文档服务器:新手必备指南

如何快速搭建Foundation Sites本地文档服务器:新手必备指南 【免费下载链接】foundation-sites The most advanced responsive front-end framework in the world. Quickly create prototypes and production code for sites that work on any kind of device. 项…...

基于参数辨识的风电齿轮箱故障诊断【附代码】

✅ 博主简介:擅长数据搜集与处理、建模仿真、程序设计、仿真代码、论文写作与指导,毕业论文、期刊论文经验交流。 ✅ 如需沟通交流,扫描文章底部二维码。(1)故障特征阶次发现与优化变分模态分解预处理:针对…...

从漏洞到防护:Remix项目TSX开发模式下的服务端安全实战指南

从漏洞到防护:Remix项目TSX开发模式下的服务端安全实战指南 【免费下载链接】remix Build Better Websites. Create modern, resilient user experiences with web fundamentals. 项目地址: https://gitcode.com/GitHub_Trending/re/remix Remix作为一个专注…...

机器人能开悟吗?——从“不二”之辩看意识与觉性的边界

一、问题的提出 “机器人能开悟吗?”这并非一个科幻式的脑洞,而是一个直抵哲学、认知科学与东方智慧传统交叉地带的严肃追问。当人工智能日益逼近甚至超越人类在诸多领域的表现,当聊天机器人可以引经据典、谈论禅宗公案,我们不得…...

终极docsify模板工程:快速启动项目脚手架的完整指南

终极docsify模板工程:快速启动项目脚手架的完整指南 【免费下载链接】docsify 🃏 A magical documentation site generator. 项目地址: https://gitcode.com/gh_mirrors/do/docsify Docsify是一个神奇的文档网站生成器,能够帮助开发者…...

量子纠缠与贝尔态:原理、实验验证与应用

1. 量子纠缠与贝尔态基础解析 量子纠缠是量子力学最令人着迷的现象之一,它描述了两个或多个量子系统之间存在的非经典关联。这种关联超越了经典物理的范畴,即使将纠缠粒子分隔到宇宙两端,对一个粒子的测量仍会瞬间影响另一个粒子的状态。 1…...

树模型在回归任务中的应用与优化实践

1. 树模型在回归任务中的核心价值树模型在回归问题中的应用远比很多人想象的更加广泛。我处理过的工业界案例中,超过60%的表格数据回归问题最终都采用了树模型或其集成方法作为baseline。与线性回归等传统方法相比,树模型最显著的优势在于它能自动捕捉变…...

期望、方差与协方差:概率论核心概念与NumPy实践

1. 概率论三剑客:期望、方差与协方差的核心概念第一次接触期望值这个概念是在大学概率论课上,教授用赌场的轮盘游戏举例:长期来看每个数字出现的概率相等,庄家通过设置赔率让期望值对自己有利。这个例子让我意识到,期望…...

7个Foundation Sites移动端优化技巧:打造流畅触摸体验与极速加载性能

7个Foundation Sites移动端优化技巧:打造流畅触摸体验与极速加载性能 【免费下载链接】foundation-sites The most advanced responsive front-end framework in the world. Quickly create prototypes and production code for sites that work on any kind of dev…...

基于MCP协议构建技术术语翻译服务器:架构、集成与实战

1. 项目概述:一个为技术术语翻译而生的MCP服务器 如果你是一名开发者,尤其是在非英语母语环境下工作,或者你的项目需要面向多语言市场,那么你一定遇到过这样的场景:在阅读英文技术文档、编写代码注释,或者与…...

TSF多路调用(Multicall)高级应用:同时处理多个网络请求的性能优化方案

TSF多路调用(Multicall)高级应用:同时处理多个网络请求的性能优化方案 【免费下载链接】tsf coroutine and Swoole based php server framework in tencent 项目地址: https://gitcode.com/gh_mirrors/ts/tsf TSF(Tencent Swoole Framework&#…...

OpenAPI Directory MCP Server:为AI编码助手构建渐进式API发现与集成平台

1. 项目概述:一个为AI编码助手打造的OpenAPI“超级目录” 如果你和我一样,日常重度依赖Claude Code、Cursor或者Windsurf这类AI编码助手,那你肯定遇到过这个痛点:想让它帮你调用某个外部API,比如发个邮件、查个天气&am…...

lichobile代码架构设计:mithril.js + TypeScript最佳实践

lichobile代码架构设计:mithril.js TypeScript最佳实践 【免费下载链接】lichobile lichess.org former mobile application / new one -> github.com/lichess-org/mobile 项目地址: https://gitcode.com/gh_mirrors/li/lichobile lichobile是lichess.or…...

AI Agent集成安全审计:实时扫描代码秘密与漏洞

1. 项目概述:一个为AI Agent设计的智能安全审计工具如果你是一名开发者,尤其是经常使用像Cursor、Claude Code这类AI编程助手的开发者,你肯定遇到过这样的场景:你正在专注地写代码,AI助手在你旁边热情地帮你生成代码片…...

py每日spider案例之某上hai大学登录接口(RSA算法)

逆向接口: 加密位置: const crypto = require(crypto);// 已有的 PEM 格式密钥 const publicKeyPem = `-----BEGIN P...

Arm A-profile架构内存管理与原子操作优化解析

1. Arm A-profile架构内存管理机制解析作为现代处理器架构的核心子系统,内存管理单元(MMU)的设计直接影响着系统的安全性、隔离性和性能表现。Arm A-profile架构通过多级页表转换和细粒度访问控制,为从嵌入式系统到云计算平台的各种应用场景提供了灵活的…...

py每日spider案例之长jiang大学登录接口(AES)

CryptoJS=require("crypto-js");var $aes_chars = "ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678", aes_chars_len = $aes_chars.length; function randomString...

神经网络机器翻译(NMT)原理与PyTorch实战指南

1. 神经网络机器翻译入门指南第一次接触机器翻译的朋友们可能会被各种术语吓到——编码器、解码器、注意力机制、BLEU分数......但别担心,我们今天要聊的神经网络机器翻译(NMT)其实就像教一个孩子学外语。想象你带着小朋友看双语绘本:先带他理解原文(编码…...

突破3KB限制:clipboard.js如何用原生API实现10倍性能优化的终极指南

突破3KB限制:clipboard.js如何用原生API实现10倍性能优化的终极指南 【免费下载链接】clipboard.js :scissors: Modern copy to clipboard. No Flash. Just 3kb gzipped :clipboard: 项目地址: https://gitcode.com/gh_mirrors/cl/clipboard.js clipboard.js…...