写点什么

Maven 将要投入 Guice 的怀抱

  • 2010-02-11
  • 本文字数:1241 字

    阅读完需:约 4 分钟

Sonatype 是一家专业的服务公司,资助了很多 Maven 开发者的开发工作。近日 Sonatype 计划将 Maven 迁移到 Guice Dependency Injection(DI)容器上的插件层以替代 Plexus DI 容器。显然,使用 Guice 并不是一个草率的决定。Plexus 是个过时的 DI 容器,用于 Maven 的所用版本中。 Jason van Zyl (Maven 项目与 Sonatype 创建者)说最初在构想 Maven 1.0 时之所以使用 Plexus 是因为它是当时仅有的几个选择之一;在那个时候,Avalon(已经废弃的 Apache 项目)则是另一个知名的 DI 解决方案。

Maven 是个构建工具,采取约定优于配置的启发式手段进行应用的构建。虽然功能非常强大,但还是有很多人抱怨 Maven 不太灵活。要想通过 Maven 完成某个任务,用户需要对已有的插件进行配置(这非常简单)或是编写自己的插件,但很多开发者都不愿意写插件。插件都会用到 Maven 运行时中的 Plexus。插件开发者需要掌握 Plexus 才能定制 Maven 插件或是更好地理解现有的插件——这非常不爽,因为 Plexus 的文档非常差劲。除了差劲的文档外,van Zyl 还提到了用 Guice 替换掉 Plexus 的诸多原因。他呼吁大家不要再向 Plexus 项目进行提交了,因为 Maven 项目不打算自己构建并支持 DI 容器,而是向开发者及构建者提供构建工具与基础设施。

同时,另一个围绕着 Maven 进行的项目(叫做 Polyglot Maven )承诺了很多增强以简化 Maven 使用与插件的编写,这包括支持用其他语言(如 Groovy 或是 Scala 等)编写 Maven pom 文件。

Guice 是由 Google(其中包括 Bob Lee )开发的一个流行的 DI 容器。凭借 Guice,我们能够通过编程的方式将实现类绑定到接口上,然后通过 Guice @Inject 注解将生成的实例注入到构造方法、方法或是属性中。

最近,Guice 增加了对 JSR 330 的支持。JSR 330 定义了一套可移植又好用的 DI 功能子集,将被不同的 DI 容器实现。现在就有很多 DI 容器已经实现了该规范,如 Guice 和 SpringSource 的 Spring Framework 。Bob Lee 和 Jason van Zyl 都是 JSR 330 专家组的成员。Maven 的 Guice 支持将通过 JSR 330 注解实现,这样就具备了可移植性。为了确保能从 Plexus 平滑迁移到 Guice 上,Maven 将使用 Guice 构建一个桥接层。在经过了多方比较后最终确定 Maven 是唯一一个能够轻松从 Plexus 进行迁移的 DI 容器,这样最后的决定也就不言而喻了。

Guice 还提供了其他一些优秀的特性:支持 peaberry( peaberry 是构建在 Guice 上的一个扩展模块,可以对动态 OSGi 服务进行解析和注入)、类型安全及定义良好的错误消息等。虽说某些特性并非 Guice 所独有,但 Guice 的的确确为我们提供了一个选择。Maven 团队现在不得不支持 Guice 的一个修补版本以满足其需求。van Zyl 说大部分内容正在实现当中,而有些则已经实现了。尚未实现的要么是不太重要的,要么仍处在测试和验证阶段。

其他一些项目(如知名的 Nexus server、Tycho 等等)也已经准备开始集成 Guice 了,在 Sonatype 最终完成 Maven 的重构后,这些集成也会延伸至 Sonatype 的其他项目中。

查看英文原文: Maven to be Built on Guice

2010-02-11 19:462653
用户头像

发布了 88 篇内容, 共 266.1 次阅读, 收获喜欢 8 次。

关注

评论

发布
暂无评论
发现更多内容

k8s上运行我们的springboot服务之——简单的架构思考

柠檬

k8s springboot

健康饮食和定期运动带给我们的一点启示

董一凡

生活质量

深入浅出SpringMVC系列~

程序员的时光

spring springmvc

[从零学习Spring Cloud]Nacos配置中心

玏佾

Spring Cloud nacos

分布式数据库

Leiy

我的事务为什么会失效

JFound

spring

小岑的架构学习笔记-架构是什么?

程序员小岑

程序员的晚餐 | 5 月 21 日 四季豆炒腊肠

清远

美食

云上数据库类产品的模式与发展趋势

韩超

数据库 redis 腾讯云 阿里云

乙己说:NUMA是个啥?

再见小飞侠

jdk G1 ZGC 内存

语雀性感,印象迟暮。

彭宏豪95

学习 工具 在线办公

永中云转换新升级 文档在线预览增添更多选择

DT极客

Android | Tangram动态页面之路(六)数据分离

哈利迪

android

数据产品经理实战-开篇

第519区

产品经理

科学理论的反思

美多丽可

学习

Python 如何随机打乱列表(List)排序

BigYoung

Python List random 随机

两边夹的应用三

孙苏勇

算法 两边夹

c++代码整洁之道

泰伦卢

c c++ C#

k8s上运行我们的springboot服务之——热点数据

柠檬

redis

KubeSphere权威指南(一)--------使用KubeSphere创建Percona Server,并对外暴露端口

赵欣

k8s percona server

极客时间学习心得:用分类和聚焦全面夯实技术认知

Anfernee Hu

学习

怎么用"设计思维"思考产品?

Yanel 说敏捷产品

产品 设计 产品设计 产品开发

Spring注入的对象到底是什么类型

JFound

spring

小岑的架构学习笔记-架构设计的历史背景

程序员小岑

传统岗位新挑战:信息安全之路

nexpose

安全架构师 安全 安全管理

乙己说:LRU实现思路整理

再见小飞侠

缓存 LeetCode Go 语言

Golang testing: “no test files”

北纬32°

Go 语言

实战!我用 Wireshark 让你 “看得见“ TCP

小林coding

Linux TCP 计算机网络

JVM源码分析之JVM启动流程

猿灯塔

高内聚与低耦合

落英亭郎

面向对象 高内聚 低耦合

要弄清楚if/switch的本质区别,以及优化方式

张驰

Java

Maven将要投入Guice的怀抱_Java_Josh Long_InfoQ精选文章