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

DDD难落地?就让AI干吧! - cleanddd-skills介绍恐

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(HTTP)主要操作是PUT上传/覆盖GET下载DELETE删除HEAD获取元数据不支持seek或部分写入。一致性模型不同的对象存储实现下有不同的一致性模型。可能是强一致性如ceph也可能是最终一致性。整理如下表所示image将对象存储S3 协议等挂载为本地文件系统FUSE是业界的常见需求目的是为了让不支持 S3 API 的传统应用也能利用对象存储的低成本和无限容量。由于我们在上一部分分析了“文件系统”与“对象存储”存在巨大的语义鸿沟因此这些 FUSE 工具的核心设计难点都在于如何用笨重的 HTTP 对象接口去模拟灵活的 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。寂仄都黑

相关文章:

DDD难落地?就让AI干吧! - cleanddd-skills介绍恐

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

基于File-Based App开发MVP项目汤

Issue 概述 先来看看提交这个 Issue 的作者是为什么想到这个点子的,以及他初步的核心设计概念。?? 本 PR 实现了 Apache Gravitino 与 SeaTunnel 的集成,将其作为非关系型连接器的外部元数据服务。通过 Gravitino 的 REST API 自动获取表结构和元数据&…...

FastAPI项目半夜报警吵醒你?聊聊告警这事儿怎么搞!翱

Issue 概述 先来看看提交这个 Issue 的作者是为什么想到这个点子的,以及他初步的核心设计概念。?? 本 PR 实现了 Apache Gravitino 与 SeaTunnel 的集成,将其作为非关系型连接器的外部元数据服务。通过 Gravitino 的 REST API 自动获取表结构和元数据&…...

解锁毕业论文新姿势:书匠策AI,你的学术超级英雄![特殊字符]

在学术的征途中,毕业论文就像是一座巍峨的山峰,让无数英雄好汉望而却步。选题迷茫、资料难寻、结构混乱、写作卡壳……这些问题像是一道道难关,考验着每一位学子的智慧和毅力。但别怕,今天我要给大家介绍一位学术界的超级英雄——…...

【技术解析】llama.cpp中的量化计算与RVV加速实现

1. llama.cpp中的量化计算机制剖析 在边缘计算设备上运行大语言模型时,量化技术就像给模型"瘦身"的魔法。llama.cpp作为轻量级推理框架,其量化实现堪称教科书级别的优化案例。我曾在树莓派上实测过量化效果,Q4_0模型体积只有原版的…...

ARM 架构 JuiceFS 性能优化:基于 MLPerf 的实践与调优愿

Qt是一个跨平台C图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本笔记将重点介绍QSpinBox数值微调组件的常用方法及灵活应用。…...

SQL如何优化频繁的数据分页操作_ROW_NUMBER索引技巧

OFFSET FETCH 越翻越慢是因为OFFSET必须顺序扫描并跳过前N行,无法直接定位,导致大数据量时性能骤降;仅适用于前端下拉加载前几页或极小分页场景。为什么 OFFSET FETCH 越翻越慢?因为 OFFSET 会强制数据库跳过前面所有行&#xff0…...

Serverless+WebAssembly:构建下一代高性能后端接口实战

随着云原生技术的普及,Serverless架构凭借按需计费、弹性伸缩的特性,成为后端接口开发的主流选择之一,但传统Serverless平台依赖Node.js、Python等预置语言环境,冷启动延迟高、资源隔离性弱的问题始终制约着其在高性能场景的应用。…...

QModMaster:如何用开源Qt框架构建专业级Modbus工业通信解决方案

QModMaster:如何用开源Qt框架构建专业级Modbus工业通信解决方案 【免费下载链接】qModbusMaster Fork of QModMaster (https://sourceforge.net/p/qmodmaster/code/ci/default/tree/) 项目地址: https://gitcode.com/gh_mirrors/qm/qModbusMaster QModMaster…...

3步轻松备份你的QQ空间:GetQzonehistory完整导出指南

3步轻松备份你的QQ空间:GetQzonehistory完整导出指南 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否还记得十年前在QQ空间写下的第一条说说?那些青涩的文…...

蓝牙耳机天线匹配调试实战:从仪器校准到阻抗调整的完整流程

蓝牙耳机天线匹配调试实战:从仪器校准到阻抗调整的完整流程 在无线音频设备领域,蓝牙耳机的射频性能直接决定了用户体验。天线作为信号收发的门户,其匹配调试是产品开发中最关键的环节之一。本文将深入剖析从仪器准备到参数优化的全流程操作要…...

从BERT到Qwen-MoE:SITS2026揭示多语言参数共享的5个致命假设(附2024-2026演进时间轴)

第一章:SITS2026演讲:大模型多语言支持 2026奇点智能技术大会(https://ml-summit.org) 在SITS2026主会场,来自全球12个国家的37个研究团队联合发布了《大模型多语言能力基准v2.1》,首次将低资源语言(如斯瓦希里语、伊…...

从数学原理到Python实现:最小公倍数算法的前世今生

从数学原理到Python实现:最小公倍数算法的前世今生 在数字的海洋中,两个看似毫不相关的整数之间,往往隐藏着精妙的数学联系。最小公倍数(LCM)作为连接这些数字的桥梁,不仅在现代编程中扮演着重要角色&#…...

Rust错误处理实战

Rust错误处理实战后端转 Rust 的萌新,ID "第一程序员"——名字大,人很菜(暂时)。正在跟所有权和生命周期死磕,日常记录 Rust 学习路上的踩坑经验和"啊哈时刻",代码片段保证能跑。保持学…...

【视觉理解奇点临界点】:2026奇点大会公布的7项VLM关键指标中,已有4项突破人类标注一致性阈值

第一章:【视觉理解奇点临界点】:2026奇点大会公布的7项VLM关键指标中,已有4项突破人类标注一致性阈值 2026奇点智能技术大会(https://ml-summit.org) 视觉语言模型(VLM)正经历一场静默却决定性的范式迁移——其核心判…...

Rust构建系统实战

Rust构建系统实战后端转 Rust 的萌新,ID "第一程序员"——名字大,人很菜(暂时)。正在跟所有权和生命周期死磕,日常记录 Rust 学习路上的踩坑经验和"啊哈时刻",代码片段保证能跑。保持学…...

HagiCode Desktop 混合分发架构解析:如何用 PP 加速大文件下载闻

一、Actor 模型:不是并发技巧,而是领域单元 Actor 模型的本质是: Actor 是独立运行的实体 Actor 之间只通过消息交互 Actor 内部状态不可被外部直接访问 Actor 自行决定如何处理收到的消息 Actor 模型真正解决的是: 如何在不共享状…...

NLopt实战避坑:C++调用时那些官方文档没细说的坑(附完整代码示例)

NLopt实战避坑:C调用时那些官方文档没细说的坑(附完整代码示例) 在工程实践中,非线性优化问题无处不在。从机器人路径规划到金融衍生品定价,从计算机视觉中的相机标定到工业设计中的参数优化,NLopt作为一款…...

NewPing超声波测距库:嵌入式实时测距的非阻塞实现

1. NewPing超声波传感器驱动库深度解析:面向嵌入式系统的高性能测距实现1.1 库定位与工程价值NewPing 是一款专为嵌入式平台(尤其是Arduino生态)设计的超声波传感器驱动库,其核心目标并非简单封装硬件时序,而是系统性解…...

UniApp分包避坑指南:pages.json配置常见错误与各平台大小限制详解

UniApp分包实战手册:从配置陷阱到多平台适配策略 第一次在UniApp项目里尝试分包时,我盯着微信开发者工具里那个刺眼的"主包超限"警告整整十分钟。这就像玩俄罗斯方块——明明每个模块都精心设计,却在最后关头因为几KB的差距功亏一篑…...

免费查AI率平台横评:知网、维普、万方检测结果到底差多少

免费查AI率平台横评:知网、维普、万方检测结果到底差多少 这两天帮学妹查论文的AI率,同一篇文章分别在知网、维普、万方上检测了一遍,结果把我整懵了——三个平台给出的AI率差了将近20个百分点。 这不是个例。我后来又拿了四五篇不同专业的论…...

Python的__getattr__动态代理

Python魔法方法__getattr__的奇妙世界 在Python中,__getattr__是一个特殊方法,它允许开发者动态拦截未定义属性的访问,为对象行为注入无限可能。无论是实现懒加载、动态API调用,还是构建灵活代理模式,__getattr__都能…...

技术方案深度解析:Cursor-Free-VIP实现AI编程工具功能解锁

技术方案深度解析:Cursor-Free-VIP实现AI编程工具功能解锁 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your…...

小红背单词【牛客tracker 每日一题】

小红背单词 时间限制:1秒 空间限制:256M 知识点:小红书 哈希模拟 网页链接 牛客tracker 牛客tracker & 每日一题,完成每日打卡,即可获得牛币。获得相应数量的牛币,能在【牛币兑换中心】&#xff0…...

3分钟解锁Illustrator批量替换魔法:告别重复劳动的终极指南

3分钟解锁Illustrator批量替换魔法:告别重复劳动的终极指南 【免费下载链接】illustrator-scripts Adobe Illustrator scripts 项目地址: https://gitcode.com/gh_mirrors/il/illustrator-scripts 你是否曾经面对过这样的场景?客户要求将设计稿中…...

React/Vue项目部署后,刷新页面就404?一个Nginx配置帮你搞定

React/Vue项目部署后刷新页面404?Nginx配置终极解决方案 刚部署完React/Vue项目时,很多开发者都会遇到一个诡异现象:首页访问正常,但点击内部路由后再刷新页面,浏览器突然弹出404错误。这就像魔术师的手帕突然消失一样…...

大麦网智能抢票助手终极教程:一键配置快速抢票指南

大麦网智能抢票助手终极教程:一键配置快速抢票指南 【免费下载链接】Automatic_ticket_purchase 大麦网抢票脚本 项目地址: https://gitcode.com/GitHub_Trending/au/Automatic_ticket_purchase 大麦网智能抢票助手是一款高效的大麦网抢票脚本,能…...

WSL2中Ubuntu主机名修改全攻略:告别大写字母烦恼

WSL2中Ubuntu主机名修改全攻略:告别大写字母烦恼 在开发者的日常工作中,WSL2已经成为连接Windows与Linux世界的桥梁。然而,这个看似完美的解决方案却隐藏着一个令人头疼的小问题——默认主机名中的大写字母。当你在Ubuntu终端中看到那个包含大…...

基于改进YOLO26的+ ECA + BiFPN + P2小目标检测头的高速铁路沿线异物智能检测系统 铁路异物识别 改进yolov26算法

Enhanced-YOLO26s 高速铁路异物检测系统 基于改进YOLO26s ECA BiFPN P2小目标检测头的高速铁路沿线异物智能检测系统 专为高铁轨道、接触网、沿线环境设计,实现小目标、复杂背景、恶劣天气下的实时、高精度异物入侵检测,保障高铁行车安全。&#x1f4…...

FortiGate 7.4.0 CVE-2024-23113:从协议逆向到格式化字符串漏洞的深度剖析

1. FortiGate 7.4.0漏洞背景与影响范围 FortiGate作为企业级防火墙的标杆产品,其安全性直接关系到数百万企业的网络边界防护。2024年初曝光的CVE-2024-23113漏洞之所以引发广泛关注,是因为它涉及FortiGate Manager(FGFM)服务的核心…...