当前位置: 首页 > 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延迟最低,吞吐量极高,也就是“数据离…...

如何快速掌握微生物组数据分析:面向科研人员的完整指南

如何快速掌握微生物组数据分析:面向科研人员的完整指南 【免费下载链接】curatedMetagenomicData Curated Metagenomic Data of the Human Microbiome 项目地址: https://gitcode.com/gh_mirrors/cu/curatedMetagenomicData 在当今生物信息学研究领域&#x…...

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

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

Kubernetes原生服务发现扛不住大模型?3种云原生注册增强模式实测对比:延迟↓67%,注册成功率↑99.992%

第一章:大模型工程化服务发现与注册机制 2026奇点智能技术大会(https://ml-summit.org) 在大模型工程化落地过程中,服务发现与注册机制是实现弹性扩缩容、多版本灰度发布与跨集群协同推理的核心基础设施。不同于传统微服务,大模型服务具有高…...

Keil4与Win10兼容性全攻略:解决管理员模式运行报错问题

Keil4与Win10兼容性全攻略:解决管理员模式运行报错问题 当你在Windows 10或11上双击Keil4图标时,那个熟悉的报错对话框是否让你感到沮丧?作为仍在维护老旧嵌入式项目的工程师,我们常常陷入两难:既需要稳定运行传统开发…...

深度解析:LX Music Desktop开源音乐播放器的技术架构与实战应用

深度解析:LX Music Desktop开源音乐播放器的技术架构与实战应用 【免费下载链接】lx-music-desktop 一个基于 Electron 的音乐软件 项目地址: https://gitcode.com/GitHub_Trending/lx/lx-music-desktop 在数字音乐时代,音乐爱好者们面临着多重困…...

树莓派3 GPIO避坑指南:从引脚烧毁到代码报错的10个常见问题(附解决方案)

树莓派3 GPIO避坑指南:从引脚烧毁到代码报错的10个常见问题(附解决方案) 当你第一次将LED连接到树莓派的GPIO引脚,却发现它死活不亮时,那种挫败感简直让人抓狂。更糟的是,你可能还会闻到一股焦糊味——没错…...

【仅限首批参会者披露】SITS2026圆桌闭门纪要:5家头部AI企业未公开的工程化SOP与3个反直觉降本技巧

第一章:SITS2026圆桌:大模型工程化的挑战与机遇 2026奇点智能技术大会(https://ml-summit.org) 大模型工程化已从实验室原型阶段迈入规模化生产部署的关键转折点。在SITS2026圆桌讨论中,来自Meta、阿里云、Hugging Face及多家AI基建初创公司…...

XXMI启动器:一站式游戏模组管理平台的创新解决方案

XXMI启动器:一站式游戏模组管理平台的创新解决方案 【免费下载链接】XXMI-Launcher Modding platform for GI, HSR, WW and ZZZ 项目地址: https://gitcode.com/gh_mirrors/xx/XXMI-Launcher 你是否曾经为管理多个游戏的模组而烦恼?是否厌倦了在不…...

模块电源PCB Layout实战:从元件摆放到噪声抑制的完整指南

1. 模块电源PCB Layout的核心挑战 刚拿到模块电源原理图时,很多工程师会直接开始画板,结果往往要反复修改。我做过十几个电源模块项目,发现PCB布局就像下棋,开局走错几步后面就很难挽回。模块电源的特殊性在于,它同时面…...

MySQL服务启动失败?手把手教你用事件查看器精准定位1067错误根源

MySQL服务启动失败?手把手教你用事件查看器精准定位1067错误根源 当你满怀期待地点击MySQL服务的启动按钮,却看到"错误1067:进程意外终止"的冰冷提示时,那种挫败感我深有体会。作为一名经历过无数次数据库服务故障的老兵…...

PyTorch手把手实现DropPath:从ViT训练代码里挖出来的实用正则化技巧

PyTorch手把手实现DropPath:从ViT训练代码里挖出来的实用正则化技巧 在复现Vision Transformer或Swin Transformer时,我们常常会在代码库中遇到一个神秘的DropPath模块。这个看似简单的正则化技术,实际上蕴含着对深度神经网络训练过程的深刻理…...

还在为音乐管理发愁?这款开源神器让你零成本畅享音乐

还在为音乐管理发愁?这款开源神器让你零成本畅享音乐 【免费下载链接】lx-music-desktop 一个基于 Electron 的音乐软件 项目地址: https://gitcode.com/GitHub_Trending/lx/lx-music-desktop 你是否厌倦了在不同音乐平台之间来回切换?每个月支付…...

智能合约驱动的票务自动化抢票系统设计与实现

1. 为什么需要智能合约驱动的票务系统 每次热门演唱会门票开售,服务器崩溃、黄牛横行、普通用户抢不到票的场景都在重复上演。传统票务系统的中心化架构存在单点故障风险,而人工抢票软件又容易触发平台风控机制。我在实际测试中发现,即使使用…...

从ISO 17987协议到代码:一文搞懂LIN唤醒信号的CANoe自动化测试怎么写

从ISO 17987协议到代码:LIN唤醒信号的CANoe自动化测试实战指南 在汽车电子系统开发中,LIN总线作为CAN总线的补充,广泛应用于车门模块、座椅控制、空调系统等对实时性要求不高的场景。网络管理是LIN总线开发中的关键环节,其中唤醒机…...

SD-PPP深度解析:如何用ComfyUI与Photoshop打造高效AI创作工作流

1. 为什么你需要SD-PPP插件? 如果你经常在Photoshop里做设计,又对AI绘画感兴趣,那一定遇到过这样的烦恼:在PS里画到一半想加点AI生成的元素,得先导出图片,再打开Stable Diffusion网页端或ComfyUI&#xff0…...

5种技术方案解决Windows 11硬件检测失败:从TPM绕过到企业级部署全解析

5种技术方案解决Windows 11硬件检测失败:从TPM绕过到企业级部署全解析 【免费下载链接】MediaCreationTool.bat Universal MCT wrapper script for all Windows 10/11 versions from 1507 to 21H2! 项目地址: https://gitcode.com/gh_mirrors/me/MediaCreationToo…...

深度学习在文档图像矫正(Dewarp)与阅读顺序预测(ROP)中的前沿应用与实践

1. 文档图像矫正(Dewarp)技术的前世今生 第一次看到弯曲的发票被AI拉直时,我盯着屏幕愣了三秒——这简直像变魔术。你可能也遇到过类似场景:用手机拍摄纸质文档时,边缘总是扭曲变形,文字像被哈哈镜照过一样…...

零样本全色锐化实战:基于CrossDiff扩散模型的卫星图像融合保姆级教程(附PyTorch代码)

零样本全色锐化实战:基于CrossDiff扩散模型的卫星图像融合保姆级教程(附PyTorch代码) 当低分辨率的多光谱图像遇上高分辨率的全色图像,如何让它们优势互补?全色锐化技术正是解决这一问题的关键。不同于传统监督学习方法…...

掌握开源个人书库部署:Talebook从零到一的完整实践指南

掌握开源个人书库部署:Talebook从零到一的完整实践指南 【免费下载链接】talebook 一个简单好用的个人书库 项目地址: https://gitcode.com/gh_mirrors/ta/talebook Talebook是一个基于Calibre构建的现代化个人在线书库系统,它采用Vue.js前端框架…...

MinIO分布式存储实战:8节点集群搭建与性能调优全记录

MinIO分布式存储实战:8节点集群搭建与性能调优全记录 在当今数据爆炸式增长的时代,企业级对象存储解决方案已成为数字化转型的核心基础设施。MinIO作为一款高性能、云原生的分布式对象存储系统,凭借其轻量级架构、S3兼容性和出色的扩展能力&a…...

ClawdBot快速入门:详细教程解决devices approve授权问题

ClawdBot快速入门:详细教程解决devices approve授权问题 1. ClawdBot简介:你的本地AI助手 ClawdBot是一个可以在个人设备上运行的个人AI助手,它使用vLLM提供后端模型能力。与依赖云端服务的AI助手不同,ClawdBot完全在本地运行&a…...

Nucleus Co-Op:重新定义单机游戏的多人同屏革命

Nucleus Co-Op:重新定义单机游戏的多人同屏革命 【免费下载链接】nucleuscoop Starts multiple instances of a game for split-screen multiplayer gaming! 项目地址: https://gitcode.com/gh_mirrors/nu/nucleuscoop 想象一下这样的场景:你和朋…...

3步解决黑苹果EFI配置难题:OpCore-Simplify智能工具完整指南

3步解决黑苹果EFI配置难题:OpCore-Simplify智能工具完整指南 【免费下载链接】OpCore-Simplify A tool designed to simplify the creation of OpenCore EFI 项目地址: https://gitcode.com/GitHub_Trending/op/OpCore-Simplify 您是否曾因复杂的OpenCore配置…...

避坑指南:libvirt远程连接配置全解析(SSH/TCP实战示例)

避坑指南:libvirt远程连接配置全解析(SSH/TCP实战示例) 在企业级虚拟化环境中,远程管理虚拟机是运维团队的刚需。libvirt作为开源虚拟化管理工具链的核心组件,其远程连接功能却常因配置复杂成为"隐形杀手"。…...

雀魂AI助手Akagi:从麻将新手到高手的终极免费教程

雀魂AI助手Akagi:从麻将新手到高手的终极免费教程 【免费下载链接】Akagi 支持雀魂、天鳳、麻雀一番街、天月麻將,能夠使用自定義的AI模型實時分析對局並給出建議,內建Mortal AI作為示例。 Supports Majsoul, Tenhou, Riichi City, Amatsuki,…...

基于Autoware的深度相机与激光雷达融合标定实战指南

1. 深度相机与激光雷达融合标定的必要性 在自动驾驶系统中,深度相机和激光雷达是两种最常用的环境感知传感器。深度相机能够提供丰富的纹理和色彩信息,但受光照条件影响较大,且在远距离测距精度下降明显。激光雷达则具备厘米级测距精度和抗干…...

打破生态壁垒:让Windows电脑完美变身AirPlay 2接收器的终极方案

打破生态壁垒:让Windows电脑完美变身AirPlay 2接收器的终极方案 【免费下载链接】airplay2-win Airplay2 for windows 项目地址: https://gitcode.com/gh_mirrors/ai/airplay2-win 还在为Windows电脑无法接收iPhone、iPad投屏而烦恼吗?Airplay2-W…...

从Kaggle比赛到公司项目:我是如何用Baseline快速启动,靠Benchmark评估进度,并追踪SOTA保持竞争力的

从Kaggle实战到工业落地:Baseline快速验证、Benchmark科学对标与SOTA持续进化的方法论 去年接手电商评论情感分析项目时,业务方只丢来一句"希望准确率至少比现有系统高15%"。面对数百万条未标注的评论数据,我用了72小时就给出了可行…...

CSRNet-PyTorch复现实战:从零搭建人群计数模型

1. 人群计数与CSRNet基础认知 第一次接触人群计数任务时,我盯着监控画面里密密麻麻的人头直发懵。传统方法需要人工标注每个行人位置,效率低下且容易出错。而CSRNet这类深度学习模型,只需要输入监控图像,就能自动输出人群密度图和…...