AGEIPort

AGEIPort

阿里巴巴开源的高性能数据导入导出框架

AGEIPort是阿里巴巴开源的数据导入导出框架,采用事件驱动架构设计。它支持集群和单机执行模式,提供实时任务进度反馈,并针对toB业务场景提供灵活定制。该框架在阿里巴巴集团内部广泛应用,月处理数据量达300-400亿条。AGEIPort通过标准化流程和接口设计,提高了开发效率和代码可维护性,适用于各类数据处理需求。

AGEIPort数据导入导出性能优化集群执行事件驱动Github开源项目

AGEIPort 阿里巴巴通用导入导出框架

Gitter License

长期招聘,联系邮箱:guijie.rgj@alibaba-inc.com

简介

AGEIPort 是由数字供应链孵化并在阿里巴巴集团内广泛使用的一套性能卓越、稳定可靠、功能丰富、易于扩展、生态完整的数据导入导出方案。它致力于帮助开发者在复杂的企业级业务场景下快速交付高性能、体验优、易维护的数据导入导出功能,如用户页面上的Excel/CSV数据文件上传和下载。目前在阿里巴巴集团内部已有盒马、菜鸟、本地生活、阿里健康、钉钉、淘系等部门广泛使用,并成为多个技术组件的基础底座。经历多次618和双11大促考验,每月稳定导入导出数据300~400亿条。

AGEIPort 基于事件驱动架构设计整体框架,并遵循以下先进的设计理念:

  1. 透明化的集群/单机执行、串行/并行执行,大幅提升数据处理性能,开发者只需关注业务逻辑处理。
  2. 支持实时任务进度计算和反馈,避免模拟数据处理进度,提升用户体验。
  3. 面向企业级复杂业务场景,通过多种方式(声明定义、动态定义)和多个维度(配置、插件、策略、SPI)满足各种场景的个性化需求,可作为平台化、PaaS/SaaS型产品的基础底座。
  4. 沉淀多种组件,多种场景、多种功能开箱即用。
  5. 秉承GitOps设计理念,将相关的不可变基础设施封装在应用Git仓库内部,使交付物能更快、更稳定和更安全地发布和回滚。
  6. 去中心化架构,业务应用自组集群资源隔离,保证业务功能有较高的隔离性、可伸缩性和可用性。
  7. 标准化任务处理流程和代码编写,定义数据处理任务的流程与用户需实现的接口,接口间职责分离,标准化用户导入导出代码的编写,提高代码的可维护性。
  8. 明确业务领域对象,通过设计泛型接口,明确导入导出代码中的领域模型,避免业务代码中大量使用Map、JSON传参,提高代码的可维护性。
  9. 记录业务代码执行过程,辅助支持业务代码性能优化。

GEI整体架构如图所示

image

代码层面主要分为3个模块:

  1. ageiport-processor(必须模块):processor模块是框架的核心,对应上图的大部分逻辑。开发者在需要执行数据处理的业务应用中依赖并实现此模块中对应的接口,将业务逻辑编写到接口实现中。任务执行过程中会回调用户实现的接口,向用户的业务代码传输数据执行业务逻辑。processor模块中包括本地API和HTTP API,用户可以在当前或外部应用调用接口,创建任务实例在processor所在的业务应用创建并执行。

  2. ageiport-task(必须模块):task模块是框架任务处理模块,与数据库交互,向processor模块暴露HTTP接口,以支持processor模块任务执行过程中对任务定义和任务实例进行增删改查。开发者需要部署此模块并连接自己的数据库,设置部署此模块的节点网络(如DNS/K8S Service等)保证processor模块网络能访问到此task模块的部署节点。

  3. ageiport-web(可选模块):web模块为前端页面提供HTTP/Websocket接口(如任务创建、查询、上传文件、下载文件等),减少开发者重复开发Controller代码,对应上图中红色部分。若web模块的功能不符合要求,用户可以自行编写Controller代码,调用processor模块的HTTP API创建任务实例在processor所在的业务应用创建并执行。后续会开源与web模块配套的前端组件,提高开发者生产效率。

基本概念

主任务(Main Task)

执行一次导入导出任务时,框架会选择一台业务机器作为主任务机器。主任务机器执行GEI框架的代码,执行一些逻辑包括接受本次任务、任务分片,任务分发、任务进度统计、文件合并等工作。 注:单机模式下主任务和子任务在同一台机器上。

子任务(Sub Task)

子任务是用户逻辑代码的执行者,每个子任务执行整体任务的一部分。例如,导出1000条数据,如果分成10个子任务执行,每个子任务只负责自己范围内的100条数据的导出。默认情况下,子任务是根据totalCount和sliceSize计算得出的,子任务分片逻辑可自定义。

分片(Slice)

分片是将一次导入导出的全量数据或条件分成一个个的片段,每个分片是整体的一部分。以导出为例,根据本次导出数据量和配置的分片大小,框架计算总共分多少片,每一片的大小和偏移(offset)是多少。

偏移(Offset)

框架中偏移的概念用在分片中。例如,一次导出10000条数据,分片大小为1000,则第一个分片的偏移为0,第二个分片的偏移为1000,依次类推。

动态列(Dynamic Column)

很多场景下导入导出文件的数据列是动态变化的。例如,7月8日导出的数据列名称是7.8/7.9/7.10,7月9日导出的数据列名称是7.9/7.10/7.11。

泛型参数QUERY

QueryObject,映射到查询参数的类。例如,查询参数{"name":"tom"},则QueryObject应包含name字段,前端传递{"name":"tom"}参数时,会构造出一个name=tom的QueryObject。

泛型参数VIEW

ViewObject,映射到文件中某行数据的类。例如,Excel中的每行数据会被构造为这里的一个对象。

泛型参数DATA

DataObject,映射到实际写入数据源或接口的类型,一般是ViewObject执行转换后得到的类型。从文件中读取的数据,很多情况下不能直接插入数据源,需要补齐一些数据,或者添加一些额外的字段,这时候就需要有个补齐或转换操作。如果没有这种需求,V和D可以定义为相同的类型。

快速开始

可以直接下载本项目代码,运行 ageiport-test 中的单元测试用例。

请注意,运行单元测试时框架会将任务存储在本机内存中、将生成的文件存储在本机硬盘中。在部署应用至生产环境时,请参考"生产环境部署"文档进行相关调整。

可参照下列文档,体验框架的更多特性:

API参考文档

生产环境部署

导入样例及文档说明

导出样例及文档说明

集群模式任务执行

谁在使用

阿里巴巴:数字供应链、盒马、菜鸟、本地生活、阿里健康、钉钉、淘系、阿里云

联系我们

目前钉钉群受到了一些管控策略影响暂无,若有问题优先提交Issue。AGEIPort的研发同学会定期解答问题,紧急问题可联系龄一(guijie.rgj@alibaba-inc.com

编辑推荐精选

讯飞智文

讯飞智文

一键生成PPT和Word,让学习生活更轻松

讯飞智文是一个利用 AI 技术的项目,能够帮助用户生成 PPT 以及各类文档。无论是商业领域的市场分析报告、年度目标制定,还是学生群体的职业生涯规划、实习避坑指南,亦或是活动策划、旅游攻略等内容,它都能提供支持,帮助用户精准表达,轻松呈现各种信息。

AI办公办公工具AI工具讯飞智文AI在线生成PPTAI撰写助手多语种文档生成AI自动配图热门
讯飞星火

讯飞星火

深度推理能力全新升级,全面对标OpenAI o1

科大讯飞的星火大模型,支持语言理解、知识问答和文本创作等多功能,适用于多种文件和业务场景,提升办公和日常生活的效率。讯飞星火是一个提供丰富智能服务的平台,涵盖科技资讯、图像创作、写作辅助、编程解答、科研文献解读等功能,能为不同需求的用户提供便捷高效的帮助,助力用户轻松获取信息、解决问题,满足多样化使用场景。

热门AI开发模型训练AI工具讯飞星火大模型智能问答内容创作多语种支持智慧生活
Spark-TTS

Spark-TTS

一种基于大语言模型的高效单流解耦语音令牌文本到语音合成模型

Spark-TTS 是一个基于 PyTorch 的开源文本到语音合成项目,由多个知名机构联合参与。该项目提供了高效的 LLM(大语言模型)驱动的语音合成方案,支持语音克隆和语音创建功能,可通过命令行界面(CLI)和 Web UI 两种方式使用。用户可以根据需求调整语音的性别、音高、速度等参数,生成高质量的语音。该项目适用于多种场景,如有声读物制作、智能语音助手开发等。

Trae

Trae

字节跳动发布的AI编程神器IDE

Trae是一种自适应的集成开发环境(IDE),通过自动化和多元协作改变开发流程。利用Trae,团队能够更快速、精确地编写和部署代码,从而提高编程效率和项目交付速度。Trae具备上下文感知和代码自动完成功能,是提升开发效率的理想工具。

AI工具TraeAI IDE协作生产力转型热门
咔片PPT

咔片PPT

AI助力,做PPT更简单!

咔片是一款轻量化在线演示设计工具,借助 AI 技术,实现从内容生成到智能设计的一站式 PPT 制作服务。支持多种文档格式导入生成 PPT,提供海量模板、智能美化、素材替换等功能,适用于销售、教师、学生等各类人群,能高效制作出高品质 PPT,满足不同场景演示需求。

讯飞绘文

讯飞绘文

选题、配图、成文,一站式创作,让内容运营更高效

讯飞绘文,一个AI集成平台,支持写作、选题、配图、排版和发布。高效生成适用于各类媒体的定制内容,加速品牌传播,提升内容营销效果。

热门AI辅助写作AI工具讯飞绘文内容运营AI创作个性化文章多平台分发AI助手
材料星

材料星

专业的AI公文写作平台,公文写作神器

AI 材料星,专业的 AI 公文写作辅助平台,为体制内工作人员提供高效的公文写作解决方案。拥有海量公文文库、9 大核心 AI 功能,支持 30 + 文稿类型生成,助力快速完成领导讲话、工作总结、述职报告等材料,提升办公效率,是体制打工人的得力写作神器。

openai-agents-python

openai-agents-python

OpenAI Agents SDK,助力开发者便捷使用 OpenAI 相关功能。

openai-agents-python 是 OpenAI 推出的一款强大 Python SDK,它为开发者提供了与 OpenAI 模型交互的高效工具,支持工具调用、结果处理、追踪等功能,涵盖多种应用场景,如研究助手、财务研究等,能显著提升开发效率,让开发者更轻松地利用 OpenAI 的技术优势。

Hunyuan3D-2

Hunyuan3D-2

高分辨率纹理 3D 资产生成

Hunyuan3D-2 是腾讯开发的用于 3D 资产生成的强大工具,支持从文本描述、单张图片或多视角图片生成 3D 模型,具备快速形状生成能力,可生成带纹理的高质量 3D 模型,适用于多个领域,为 3D 创作提供了高效解决方案。

3FS

3FS

一个具备存储、管理和客户端操作等多种功能的分布式文件系统相关项目。

3FS 是一个功能强大的分布式文件系统项目,涵盖了存储引擎、元数据管理、客户端工具等多个模块。它支持多种文件操作,如创建文件和目录、设置布局等,同时具备高效的事件循环、节点选择和协程池管理等特性。适用于需要大规模数据存储和管理的场景,能够提高系统的性能和可靠性,是分布式存储领域的优质解决方案。

下拉加载更多