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

编辑推荐精选

Vora

Vora

免费创建高清无水印Sora视频

Vora是一个免费创建高清无水印Sora视频的AI工具

Refly.AI

Refly.AI

最适合小白的AI自动化工作流平台

无需编码,轻松生成可复用、可变现的AI自动化工作流

酷表ChatExcel

酷表ChatExcel

大模型驱动的Excel数据处理工具

基于大模型交互的表格处理系统,允许用户通过对话方式完成数据整理和可视化分析。系统采用机器学习算法解析用户指令,自动执行排序、公式计算和数据透视等操作,支持多种文件格式导入导出。数据处理响应速度保持在0.8秒以内,支持超过100万行数据的即时分析。

AI工具酷表ChatExcelAI智能客服AI营销产品使用教程
TRAE编程

TRAE编程

AI辅助编程,代码自动修复

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

AI工具TraeAI IDE协作生产力转型热门
AIWritePaper论文写作

AIWritePaper论文写作

AI论文写作指导平台

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

AI辅助写作AI工具AI论文工具论文写作智能生成大纲数据安全AI助手热门
博思AIPPT

博思AIPPT

AI一键生成PPT,就用博思AIPPT!

博思AIPPT,新一代的AI生成PPT平台,支持智能生成PPT、AI美化PPT、文本&链接生成PPT、导入Word/PDF/Markdown文档生成PPT等,内置海量精美PPT模板,涵盖商务、教育、科技等不同风格,同时针对每个页面提供多种版式,一键自适应切换,完美适配各种办公场景。

AI办公办公工具AI工具博思AIPPTAI生成PPT智能排版海量精品模板AI创作热门
潮际好麦

潮际好麦

AI赋能电商视觉革命,一站式智能商拍平台

潮际好麦深耕服装行业,是国内AI试衣效果最好的软件。使用先进AIGC能力为电商卖家批量提供优质的、低成本的商拍图。合作品牌有Shein、Lazada、安踏、百丽等65个国内外头部品牌,以及国内10万+淘宝、天猫、京东等主流平台的品牌商家,为卖家节省将近85%的出图成本,提升约3倍出图效率,让品牌能够快速上架。

iTerms

iTerms

企业专属的AI法律顾问

iTerms是法大大集团旗下法律子品牌,基于最先进的大语言模型(LLM)、专业的法律知识库和强大的智能体架构,帮助企业扫清合规障碍,筑牢风控防线,成为您企业专属的AI法律顾问。

SimilarWeb流量提升

SimilarWeb流量提升

稳定高效的流量提升解决方案,助力品牌曝光

稳定高效的流量提升解决方案,助力品牌曝光

Sora2视频免费生成

Sora2视频免费生成

最新版Sora2模型免费使用,一键生成无水印视频

最新版Sora2模型免费使用,一键生成无水印视频

下拉加载更多