长期招聘,联系邮箱:guijie.rgj@alibaba-inc.com
AGEIPort 是由数字供应链孵化并在阿里巴巴集团内广泛使用的一套性能卓越、稳定可靠、功能丰富、易于扩展、生态完整的数据导入导出方案。它致力于帮助开发者在复杂的企业级业务场景下快速交付高性能、体验优、易维护的数据导入导出功能,如用户页面上的Excel/CSV数据文件上传和下载。目前在阿里巴巴集团内部已有盒马、菜鸟、本地生活、阿里健康、钉钉、淘系等部门广泛使用,并成为多个技术组件的基础底座。经历多次618和双11大促考验,每月稳定导入导出数据300~400亿条。
AGEIPort 基于事件驱动架构设计整体框架,并遵循以下先进的设计理念:
GEI整体架构如图所示

代码层面主要分为3个模块:
ageiport-processor(必须模块):processor模块是框架的核心,对应上图的大部分逻辑。开发者在需要执行数据处理的业务应用中依赖并实现此模块中对应的接口,将业务逻辑编写到接口实现中。任务执行过程中会回调用户实现的接口,向用户的业务代码传输数据执行业务逻辑。processor模块中包括本地API和HTTP API,用户可以在当前或外部应用调用接口,创建任务实例在processor所在的业务应用创建并执行。
ageiport-task(必须模块):task模块是框架任务处理模块,与数据库交互,向processor模块暴露HTTP接口,以支持processor模块任务执行过程中对任务定义和任务实例进行增删改查。开发者需要部署此模块并连接自己的数据库,设置部署此模块的节点网络(如DNS/K8S Service等)保证processor模块网络能访问到此task模块的部署节点。
ageiport-web(可选模块):web模块为前端页面提供HTTP/Websocket接口(如任务创建、查询、上传文件、下载文件等),减少开发者重复开发Controller代码,对应上图中红 色部分。若web模块的功能不符合要求,用户可以自行编写Controller代码,调用processor模块的HTTP API创建任务实例在processor所在的业务应用创建并执行。后续会开源与web模块配套的前端组件,提高开发者生产效率。
执行一次导入导出任务时,框架会选择一台业务机器作为主任务机器。主任务机器执行GEI框架的代码,执行一些逻辑包括接受本次任务、任务分片,任务分发、任务进度统计、文件合并等工作。 注:单机模式下主任务和子任务在同一台机器上。
子任务是用户逻辑代码的执行者,每个子任务执行整体任务的一部分。例如,导出1000条数据,如果分成10个子任务执行,每个子任务只负责自己范围内的100条数据的导出。默认情况下,子任务是根据totalCount和sliceSize计算得出的,子任务分片逻辑可自定义。
分片是将一次导入导出的全量数据或条件分成一个个的片段,每个分片是整体的一部分。以导出为例,根据本次导出数据量和配置的分片大小,框架计算总共分多少片,每一片的大小和偏移(offset)是多少。
框架中偏移的概念用在分片中。例如,一次导出10000条数据,分片大小为1000,则第一个分片的偏移为0,第二个分片的偏移为1000,依次类推。
很多场景下导入导出文件的数据列是动态变化的。例如,7月8日导出的数据列名称是7.8/7.9/7.10,7月9日导出的数据列名称是7.9/7.10/7.11。
QueryObject,映射到查询参数的类。例如,查询参数{"name":"tom"},则QueryObject应包含name字段,前端传递{"name":"tom"}参数时,会构造出一个name=tom的QueryObject。
ViewObject,映射到文件中某行数据的类。例如,Excel中的每行数据会被构造为这里的一个对象。
DataObject,映射到实际写入数据源或接口的类型,一般是ViewObject执行转换后得到的类型。从文件中读取的数据,很多情况下不能直接插入数据源,需要补齐一些数据,或者添加一些额外的字段,这时候就需要有个补齐或转换操作。如果没有这种需求,V和D可以定义为相同的类型。
可以直接下载本项目代码,运行 ageiport-test 中的单元测试用例。
请注意,运行单元测试时框架会将任务存储在本机内存中、将生成的文件存储在本机硬盘中。在部署应用至生产环境时,请参考"生产环境部署"文档进行相关调整。
可参照下列文档,体验框架的更多特性:
阿里巴巴:数字供应链、盒马、菜鸟、本地生活、阿里健康、钉钉、淘系、阿里云
目前钉钉群受到了一些管控策略影响暂无,若有问题优先提交Issue。AGEIPort的研发同学会定期解答问题,紧急问题可联系龄一(guijie.rgj@alibaba-inc.com)


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


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


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


实时语音翻译/同声传译工具
Transly是一个多场景的AI大语言模型驱动的同声传译、专业翻译助手,它拥有超精准的音频识别翻译能力,几乎零延迟的使用体验和支持多国语言可以让你带它走遍全球,无论你是留学生、商务人士、韩剧美剧爱好者,还是出国游玩、多国会议、跨国追星等等,都可以满足你所有需要同传的场景需求,线上线下通用,扫除语言障碍,让全世界的语言交流不再有国界。


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


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


最强AI数据分析助手
小浣熊家族Raccoon,您的AI智能助手,致力于通过先进的人工智能技术,为用户提供高效、便捷的智能服务。无论是日常咨询还是专业问题解答,小浣熊都能以快速、准确的响应满足您的需求,让您的生活更加智能便捷。


像人一样思考的AI智能体
imini 是一款超级AI智能体,能根据人类指令,自主思考、自主完成、并且交付结果的AI智能体。


AI数字人视频创作平台
Keevx 一款开箱即用的AI数字人视频创作平台,广泛适用于电商广告、企业培训与社媒宣传,让全球企业与个人创作者无需拍摄剪辑,就能快速生成多语言、高质量的专业视频。


一站式AI创作平台
提供 AI 驱动的图片、视频生成及数字人等功能,助力创意创作
最新AI工具、AI资讯
独家AI资源、AI项目落地

微信扫一扫关注公众号