首页
/ Moon项目v1.36.0版本发布:工具链插件与远程缓存能力升级

Moon项目v1.36.0版本发布:工具链插件与远程缓存能力升级

2025-06-16 07:06:33作者:苗圣禹Peter

Moon是一个现代化的构建系统和任务运行器,旨在为多语言、多项目的代码库提供统一的开发体验。它通过智能的任务编排、依赖管理和缓存机制,显著提升了开发团队的构建效率。本次发布的v1.36.0版本带来了多项重要更新,特别是在工具链插件支持和远程缓存功能方面有了显著增强。

工具链插件支持全面升级

本次版本最引人注目的变化是对工具链插件的不稳定支持进行了大幅扩展。Moon现在允许插件通过WASM API深度参与项目的构建生命周期:

  1. 项目图扩展:插件现在可以向项目图中注入额外的依赖关系、任务定义和项目别名。这使得工具链能够根据自身特性动态调整项目结构。

  2. 环境设置与依赖安装:新增了SetupEnvironmentInstallDependencies两个核心动作,分别对应setup_environmentinstall_dependencies WASM API。这些API让插件能够在任务执行前准备必要的环境条件。

  3. 任务执行增强:插件现在可以干预任务执行过程,包括:

    • 在命令或脚本执行前注入额外参数
    • 将依赖和锁文件信息纳入哈希计算,确保缓存正确性
  4. Docker集成改进docker prune命令现在利用新的WASM API与工具链插件交互,实现了更智能的容器清理机制。

图形化工具增强

Moon的图形化分析工具现在支持自定义主机和端口配置:

  • moon action-graphmoon task-graphmoon project-graph命令新增了--host--port选项,方便开发者在不同环境中使用这些可视化工具。

输入处理优化

针对持续集成场景,v1.36.0改进了文件变更检测机制:

  • moon cimoon run命令新增--stdin选项,允许通过标准输入传递变更文件列表,而非依赖VCS命令检测。这种显式的方式避免了之前版本中出现的边缘情况问题。

远程缓存可靠性提升

远程缓存功能在本版本中获得了多项改进:

  1. 完整性验证:新增unstable_remote.cache.verifyIntegrity配置项,启用后会校验下载的缓存blob的摘要,确保数据完整无误。虽然会轻微影响性能,但大幅提高了可靠性。

  2. 失败回滚机制:当缓存恢复过程部分失败时,系统会自动清理已写入的文件,保持工作区一致性。

  3. 批量检查优化:缓存blob的存在性检查现在采用批量化并行处理,显著提升了效率。

  4. 纯环境变量配置:现在可以完全通过环境变量启用远程缓存功能,简化了配置流程。

代码生成能力扩展

模板系统新增了对复杂数据类型的支持:

  • template.yml现在支持arrayobject类型的变量,这些值必须符合JSON格式规范。
  • generator.templates配置项新增了对HTTPS归档文件的支持,可以直接从网络URL加载模板资源。

其他重要改进

  1. 任务输入限制解除:移除了对moon.{yml,pkl}作为任务输入的限制,不过在使用**/*通配符时仍会被排除。

  2. 终端提示修复:解决了终端提示验证有时不触发的问题。

  3. 缓存一致性增强

    • 修复了任务依赖的argsenv变更时缓存不失效的问题
    • 命令行环境变量现在能正确覆盖任务定义中的env
  4. 依赖关系修正

    • 修复了基于标签的任务依赖未正确创建隐式项目依赖的问题
    • 改进了任务/命令参数的引号处理逻辑

插件API扩展

工具链插件开发者将获得一系列新的WASM API:

  • 项目图操作:extend_project_graph
  • 任务扩展:extend_task_commandextend_task_script
  • 依赖管理:locate_dependencies_rootparse_manifestparse_lock
  • 多项输入输出结构的扩展,支持更丰富的操作类型和数据传递

底层升级

项目内部完成了多项技术栈更新:

  • Rust工具链升级至v1.87.0
  • proto依赖从v0.47.11升级至v0.49.1

Moon v1.36.0版本通过增强工具链插件支持和改进远程缓存等核心功能,进一步巩固了其作为现代化构建系统的地位。这些改进不仅提升了开发体验,也为更复杂的构建场景提供了可靠支持。

登录后查看全文

项目优选

收起
leetcodeleetcode
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
51
15
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
577
417
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
125
208
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
77
146
folibfolib
FOLib 是一个为Ai研发而生的、全语言制品库和供应链服务平台
Java
110
6
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
444
39
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
693
91
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
80
13
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
98
253
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
359
342