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

AI时代新型的项目管理应该是什么样的?众

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。返戏露杭

相关文章:

AI时代新型的项目管理应该是什么样的?众

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

GitHub 悄悄起飞的开源项目,想让 AI 接管你的电脑断

我为什么会发出这个疑问呢?是因为我研究Web开发中的一个问题时,HTTP请求体在 Filter(过滤器)处被读取了之后,在 Controller(控制层)就读不到值了,使用 RequestBody 的时候。 无论是字…...

BMV31M304A语音模块:I²C接口嵌入式语音播放方案

1. BMV31M304A语音播放模块深度技术解析BMV31M304A是由BEST MODULES CORP推出的专用IC接口语音播放模块,面向嵌入式系统设计,尤其适用于需要低成本、低功耗、即插即用语音提示功能的工业HMI、智能家电、安防设备及教育类开发板。该模块并非通用音频解码芯…...

终极KCC多设备兼容指南:Kindle、Kobo、ReMarkable全支持的漫画转换神器

终极KCC多设备兼容指南:Kindle、Kobo、ReMarkable全支持的漫画转换神器 【免费下载链接】kcc KCC (a.k.a. Kindle Comic Converter) is a comic and manga converter for ebook readers. 项目地址: https://gitcode.com/gh_mirrors/kc/kcc KCC(Ki…...

简明教程:实现OpenCLaw轻量级应用服务器部署及Ollama大模型本地化蓉

智能体时代的代码范式转移与 C# 的战略转型 传统的 C# 开发模式,即所谓的“工程导向型”开发,要求开发者创建一个复杂的项目结构,包括项目文件(.csproj)、解决方案文件(.sln)、属性设置以及依赖…...

Graphormer开源镜像保姆级教程:3.7GB纯Transformer模型GPU快速部署

Graphormer开源镜像保姆级教程:3.7GB纯Transformer模型GPU快速部署 1. 为什么选择Graphormer? Graphormer是微软研究院开发的基于纯Transformer架构的图神经网络模型,专门用于分子属性预测任务。与传统的图神经网络(GNN)相比,它…...

Chainlit+Qwen1.5-1.8B-GPTQ-Int4构建私有AI助手:支持文件上传与内容问答教程

ChainlitQwen1.5-1.8B-GPTQ-Int4构建私有AI助手:支持文件上传与内容问答教程 1. 学习目标与前置准备 今天我们来学习如何搭建一个功能强大的私有AI助手,这个助手不仅能进行智能对话,还能读取你上传的文件并回答相关问题。想象一下&#xff…...

终极PEFT技术教程:用少量数据高效微调大模型的完整指南

终极PEFT技术教程:用少量数据高效微调大模型的完整指南 【免费下载链接】notebooks Notebooks using the Hugging Face libraries 🤗 项目地址: https://gitcode.com/gh_mirrors/note/notebooks GitHub 加速计划 / note / notebooks项目提供了丰富…...

如何让Application Inspector完美识别C、Java、Python等多语言代码?全面解析与实用指南

如何让Application Inspector完美识别C、Java、Python等多语言代码?全面解析与实用指南 【免费下载链接】ApplicationInspector A source code analyzer built for surfacing features of interest and other characteristics to answer the question Whats in the …...

NaViL-9B惊艳效果:多页PDF截图拼接理解+跨页语义关联分析

NaViL-9B惊艳效果:多页PDF截图拼接理解跨页语义关联分析 1. 模型能力概览 NaViL-9B作为原生多模态大语言模型,在文档理解领域展现出独特优势。不同于常规图文模型仅能处理单页内容,它具备两大核心能力: 多页PDF截图拼接理解&am…...

DeepSeek-OCR-2部署案例:私有云OpenStack平台OCR服务容器化部署

DeepSeek-OCR-2部署案例:私有云OpenStack平台OCR服务容器化部署 1. 项目背景与价值 在数字化转型的浪潮中,文档数字化处理成为企业提升效率的关键环节。传统的OCR技术往往面临识别精度不足、处理速度慢、部署复杂等问题,特别是在私有云环境…...

Hive数据库入门指南:5分钟学会Flutter极速键值存储

Hive数据库入门指南:5分钟学会Flutter极速键值存储 【免费下载链接】hive Lightweight and blazing fast key-value database written in pure Dart. 项目地址: https://gitcode.com/gh_mirrors/hive/hive Hive是一款轻量级且速度极快的纯Dart键值数据库&…...

终极Pi-Hole域名白名单配置指南:3种列表的实战应用与优化技巧

终极Pi-Hole域名白名单配置指南:3种列表的实战应用与优化技巧 【免费下载链接】whitelist A simple tool to add commonly white listed domains to your Pi-Hole setup. 项目地址: https://gitcode.com/gh_mirrors/wh/whitelist GitHub 加速计划&#xff0…...

一个简洁易用的 Delphi JSON 封装库,基于 System.JSON`单元封装,提供更直观的 API廖

一、前言:什么是 OFA VQA 模型? OFA(One For All)是字节跳动提出的多模态预训练模型,支持视觉问答、图像描述、图像编辑等多种任务,其中视觉问答(VQA)是最常用的功能之一——输入一张…...

打造专属API网关监控中心:Konga自定义仪表盘完全指南

打造专属API网关监控中心:Konga自定义仪表盘完全指南 【免费下载链接】konga More than just another GUI to Kong Admin API 项目地址: https://gitcode.com/gh_mirrors/ko/konga Konga作为Kong API网关的强大管理界面,不仅提供了基础的API管理功…...

esp32-snippets自定义扩展:如何基于现有代码构建自己的工具库

esp32-snippets自定义扩展:如何基于现有代码构建自己的工具库 【免费下载链接】esp32-snippets Sample ESP32 snippets and code fragments 项目地址: https://gitcode.com/gh_mirrors/es/esp32-snippets esp32-snippets是一个包含丰富ESP32代码片段和示例的…...

PROJECT MOGFACE Keil5开发效率提升:工程配置自动化与调试脚本生成

PROJECT MOGFACE Keil5开发效率提升:工程配置自动化与调试脚本生成 你是不是也经历过这样的场景?拿到一块新的STM32开发板,比如最常见的STM32F103,兴冲冲地打开Keil5准备大干一场,结果第一步就被卡住了——新建工程、…...

基于Qwen3-ASR-1.7B的智能录音笔方案:离线语音转写实现

基于Qwen3-ASR-1.7B的智能录音笔方案:离线语音转写实现 语音转写技术正逐步从云端走向终端,Qwen3-ASR-1.7B为嵌入式设备提供了本地化语音识别的可能性 1. 方案设计思路 传统的录音笔只能记录音频,后期需要导入电脑并通过联网服务才能转换成文…...

GLM-OCR在网络安全中的应用:恶意软件截图与钓鱼网站界面分析

GLM-OCR在网络安全中的应用:恶意软件截图与钓鱼网站界面分析 最近和几个做安全的朋友聊天,他们都在抱怨一个事儿:每天要处理海量的恶意软件截图和钓鱼网站页面,眼睛都快看花了。这些图片里藏着大量关键信息,比如勒索软…...

彻底搞懂Type Challenges中的Chunk类型:从入门到精通

彻底搞懂Type Challenges中的Chunk类型:从入门到精通 【免费下载链接】type-challenges Collection of TypeScript type challenges with online judge 项目地址: https://gitcode.com/GitHub_Trending/ty/type-challenges Type Challenges是一个专注于TypeS…...

Alerta高可用部署方案:Docker、Kubernetes与云平台最佳实践

Alerta高可用部署方案:Docker、Kubernetes与云平台最佳实践 【免费下载链接】alerta Alerta monitoring system 项目地址: https://gitcode.com/gh_mirrors/al/alerta Alerta监控系统是一款功能强大的开源告警管理工具,能够帮助运维团队集中处理各…...

告别生硬过渡:用Pop实现丝滑手势交互的3个实战技巧

告别生硬过渡:用Pop实现丝滑手势交互的3个实战技巧 【免费下载链接】pop An extensible iOS and OS X animation library, useful for physics-based interactions. 项目地址: https://gitcode.com/gh_mirrors/po/pop Pop是一款强大的iOS和OS X动画库&#x…...

终极指南:如何使用Excelize实现高效多列排序与自定义排序规则

终极指南:如何使用Excelize实现高效多列排序与自定义排序规则 【免费下载链接】excelize Go language library for reading and writing Microsoft Excel™ (XLAM / XLSM / XLSX / XLTM / XLTX) spreadsheets 项目地址: https://gitcode.com/gh_mirrors/ex/exceli…...

DeepSeek-OCR实战应用:物流单据智能处理方案

DeepSeek-OCR实战应用:物流单据智能处理方案 1. 物流行业的OCR需求与挑战 1.1 物流单据处理的痛点分析 物流行业每天产生海量的运单、发票、签收单等纸质单据,传统人工录入方式面临三大核心问题: 效率瓶颈:平均每张单据需要3-…...

如何用NES.css打造复古游戏风表单提交反馈:完整微交互指南

如何用NES.css打造复古游戏风表单提交反馈:完整微交互指南 【免费下载链接】NES.css NES-style CSS Framework | ファミコン風CSSフレームワーク 项目地址: https://gitcode.com/gh_mirrors/ne/NES.css NES.css作为一款经典的红白机风格CSS框架,让…...

OpenSimpleLidar开源激光雷达:低成本DIY扫描测距仪完全指南

OpenSimpleLidar开源激光雷达:低成本DIY扫描测距仪完全指南 【免费下载链接】OpenSimpleLidar Open Source scanning laser rangefinder 项目地址: https://gitcode.com/gh_mirrors/op/OpenSimpleLidar OpenSimpleLidar是一款开源激光雷达项目,专…...

终极指南:Nodeclub社区系统的自动化测试全攻略

终极指南:Nodeclub社区系统的自动化测试全攻略 【免费下载链接】nodeclub :baby_chick:Nodeclub 是使用 Node.js 和 MongoDB 开发的社区系统 项目地址: https://gitcode.com/gh_mirrors/no/nodeclub Nodeclub是使用Node.js和MongoDB开发的社区系统&#xff0…...

Maud快速入门指南:5分钟学会使用Rust宏编写HTML模板

Maud快速入门指南:5分钟学会使用Rust宏编写HTML模板 【免费下载链接】maud :pencil: Compile-time HTML templates for Rust 项目地址: https://gitcode.com/gh_mirrors/ma/maud Maud是Rust的HTML模板引擎,通过html!宏将标记编译为专门的Rust代码…...

如何快速上手Hackberry-Pi_Zero:从开箱到运行的10个简单步骤

如何快速上手Hackberry-Pi_Zero:从开箱到运行的10个简单步骤 【免费下载链接】Hackberry-Pi_Zero A handheld Linux terminal using Raspberry pi Zero 2W as Core with 4" 720X720 TFT display 项目地址: https://gitcode.com/gh_mirrors/ha/Hackberry-Pi_Z…...

TensorFlow.js手势识别避坑指南:HandPose模型在React Native中的特殊适配

TensorFlow.js手势识别在React Native中的工程化实践:从原理到性能优化 移动端手势交互正在重塑人机交互体验,而React Native开发者面临的核心挑战在于:如何将浏览器环境优化的TensorFlow.js模型无缝迁移到跨平台场景。本文将深入解析HandPos…...