Turborepo 2.3
Turborepo 2.3 引入了多项人体工程学方面的改进
立即运行 npx @turbo/codemod migrate
进行更新,或使用 npx create-turbo@latest
开始使用。
边界 RFC
Monorepo 解锁了更快的迭代速度和令人难以置信的灵活性,但也带来了新的挑战
- 我们如何确保尊重包的公共 API?
- 我们如何向所有开发者传达代码可以在哪里使用,不能在哪里使用?
- 我们如何确保包仅在正确的上下文中使用?
这些只是在 monorepo 中构建时一个关键问题的几个例子:我们如何沟通和执行工作空间的结构完整性?
在发布此帖时,边界 RFC 仅为初始草案。以下描述的实现可能会发生变化。请参阅 RFC 本身以获取最新信息。
边界 RFC 是我们针对此问题的初始提案。在我们当前的方法中,我们希望您能够在一行代码中逐步采用边界
此外,我们希望创建一个标签系统,以便您可以使用自定义边界标记域、关注点、上下文和其他有用的元数据。
我们还计划让您能够使用标志来允许列出已有的诊断信息
这样,您可以为新代码强制执行边界,并逐步修复现有问题。
我们期待听到您关于边界 RFC 的想法和反馈。
包任务快捷方式
您现在可以使用完全限定的任务标识符来运行任务
这比使用 --filter
的等效命令(turbo run build --filter=web
)更方便,如果您有多个想要定位的任务,则可以更精确
简化缓存控制
以前,--remote-only
和 --no-cache
标志用于管理输出工件的来源和缓存。但是,我们已经看到它们是如何引起混淆的,并且在读写本地和远程缓存方面存在控制上的差距。
为了改进这一点,我们引入了一个新的 --cache
标志,它将这些标志结合在一起 - 并提供了更多的功能。
使用 local
和 remote
,您可以控制 turbo
调用的读写行为。在文档中了解更多信息。
turbo query
的持续改进
在 2.2 版本中,我们引入了 turbo query
,这是一个使用 Turborepo 对您的包和任务图的了解来检查您的存储库的功能。我们在此功能上进行了进一步的迭代,为您提供更强大的查询
- 实现了反向文件跟踪以查找哪些文件依赖于特定文件
- 用于文件跟踪的过滤器,用于查找仅类型依赖项
- 您提供的包名称现在已验证以确保它们存在
社区
自发布 Turborepo 2.2 以来,我们看到了巨大的采用和社区增长
- 26.3+ GitHub 星星
- 每周超过 340 万次 NPM 下载
- 使用 Vercel 远程缓存节省了 496 年以上的计算时间
Turborepo 是所有贡献者(包括我们的核心团队:Anthony、Chris、Nicholas 和 Tom)共同努力的结果。
感谢您持续的支持、反馈和协作,使 Turborepo 成为您首选的构建工具。