- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我开发了一个在各种项目中使用的 Java 实用程序库(类似于 Apache Commons)。
除了胖客户端之外,我还将它用于移动客户端(带有 J9 Foundation 配置文件的 PDA)。
随着时间的推移,作为单个项目开始的库分布在多个包中。结果,我最终得到了很多功能,这并不是所有项目都真正需要的。
由于这个库也在一些移动/PDA 项目中使用,我需要一种方法来收集使用的类并生成实际的专用 jar。
目前在使用这个库的项目中,我有 Ant jar 任务,它们生成(从实用程序项目)专用 jar 文件(例如:my-util-1.0-pda.jar、my-util-1.0-rcp.jar)使用包含/排除 jar 任务功能。对于移动项目,由于生成的 jar 文件的大小限制,这主要是需要的。
现在迁移到 Maven 我只是想知道是否有任何最佳实践可以达到类似的效果。我考虑以下场景:
[1] - 除了主 jar Artifact ( my-lib-1.0.jar ) 还在 内部生成我的库 使用分类器(例如: my-lib-1.0-pda.jar )使用 Maven Jar 插件或 Maven 程序集插件过滤/包含来投影单独的/专门的 Artifact 。我对这种方法不太满意,因为它污染了图书馆消费者的需求(过滤器)。
[2] - 为所有专门的客户/项目创建额外的 Maven 项目,这将“包装”“my-lib”并生成过滤的 jar Artifact (例如: my-lib-wrapper-pda-1.0 .. 。ETC)。因此,这些包装器项目将包含过滤(以生成过滤后的 Artifact )并且将仅依赖于“my-lib”项目,而客户端项目将依赖于 。 my-lib-wrapper-xxx-1.0 而不是 我的 lib-1.0 .这种方法可能看起来有问题,因为即使这样会使“my-lib”项目完好无损(没有额外的分类器和 Artifact ),基本上会使项目数量增加一倍,因为对于每个客户项目我都会有一个库,只是为了收集需要的“my-util”库中的类(“my-pda-app”项目需要“my-lib-wrapper-for-my-pda-app”项目/依赖项)。
[3] - 在每个使用该库的客户端项目中(例如: my-pda-app )添加一些专门的 Maven 插件来修剪(在生成最终 Artifact/包时)不需要的类(例如: maven-assembly-plugin、maven-jar-plugin、proguard-maven-plugin)。
以“Maven 方式”解决此类问题的最佳实践是什么?
最佳答案
出于模块化的考虑,Maven 的一般规则是“每个 POM 一个主要 Artifact ”,不应该违反此约定的原因(通常)在 How to Create Two JARs from One Project (...and why you shouldn’t) 中有很好的解释。博客文章。然而,也有合理的异常(exception)(例如,一个 EJB 项目产生一个 EJB JAR 和一个只有接口(interface)的客户端 EJB JAR)。话说回来:
提到的blog post (另请查看 Using Maven When You Can't Use the Conventions )解释了如何实现 选项 1 使用单独的配置文件或 JAR 插件 .如果您决定实现此解决方案,请记住这应该是一个异常(exception),并且它可能会使依赖项管理变得更加棘手(并且,正如您所提到的,使用“客户端过滤逻辑”污染项目)。以防万一,我会在这里使用几个 JAR 插件执行。
选项 2 与 没有太大区别选项 1 IMO(除了它将事物分开):基本上,拥有 N 个其他包装/过滤项目与在一个项目中拥有 N 个过滤规则非常相似。如果过滤有意义,我更喜欢选项 1。
我不喜欢 选项 3 完全是因为我认为图书馆的客户不应该负责“修剪”不需要的东西。首先,客户端项目不一定具有所需的知识(要修剪什么),其次,这可能会与其他插件产生很大的困惑。
但是 如果胖客户端是 不是 使用整个 我的库 (就像服务器端代码需要整个 EJB JAR),那么过滤不是处理您的情况的正确“maven 方式”。正确的方法是 选项 4 :将所有常见的东西放在一个项目中(产生 my-lib-core-1.0.jar )和特定项目中的特定部分(这将产生 my-lib-pda-1.0.jar ETC)。然后,客户将依赖于核心 Artifact 和专门的 Artifact 。
关于maven-2 - 生成具有不同/过滤类的多个 jar 的 Maven 最佳实践?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2424015/
我试图理解 Maven 模块和 Maven 项目之间的区别。哪一个是什么以及我应该在哪里?谢谢 最佳答案 maven 模块就像一个 maven“子项目”。一个 Maven 项目包含 1 个或多个模块。
我们目前没有自己的存储库。因此,当我们使用 Maven 构建时,它会在当前用户的主目录中创建 .m2 存储库。 现在有两个在 Maven Central 中找不到的第三方 jar。假设其中之一是 ha
我有 Maven 项目,但在其中一台服务器上我必须在没有 Maven 的情况下构建它。 可以使用标准 JDK 命令。在哪里可以看到 Maven 在构建项目时向 JDK 发送了哪些命令? 最佳答案 Ma
我打算将 ImageJ 用于 web 应用程序,但似乎 ImageJ maven 依赖项不在中央 maven 存储库中。 我说得对吗? 当 ImageJ 2.x 发布时,这会改变吗? 最佳答案 您可以
我可以有多个 Maven 实例吗,即 Mave 2.2.1 和 Maven 3 都指向同一个本地存储库? 我的意思是我知道我可以在技术上将每个 settings.xml 指向同一个文件夹,但从长远来看
我有两个项目,项目 A 依赖于项目 B,所以通常,我的 projectA/pom.xml 中有以下部分: projectB blabla version1 我想要实现的目标非常简
在网上的许多地方,我看到它讨论了要使 maven 构建可重现,明确指定所有使用的插件的版本号很重要,这样更新的插件就不会破坏构建。推荐的方法似乎是使用 enforcer 插件。下面是我在网上找到的复制
有没有办法暂停 Maven 执行流程以提供命令提示符,以便用户可以输入文本。 然后我希望将提供的文本存储在 Maven 属性中。 如果用户输入可以被屏蔽,那将是一个奖励。 这对于避免在 pom.xml
我正在尝试使用 maven 插件将 maven java 项目的源文件夹添加到 Eclipse。 尝试使用 org.codehaus.mojo 插件时,我收到以下错误 无法在项目应用程序框架上执行目标
我有两个几乎相同的配置文件。我不想在每个配置文件中复制配置,而是希望一个配置文件从另一个配置文件“继承”,但我没有看到使用 maven 3 执行此操作的明显方法。 在 Maven 中是否可以继承配置文
我是 Maven 新手,花了大约 3 天的时间使用程序集插件生成 zip 文件,引用 http://www.petrikainulainen.net/programming/tips-and-tric
想象一下这种情况。我有一个使用 Maven 管理的开源项目,它依赖于一个不在 Maven 存储库中的知名库(例如 jpathwatch)。我怎样才能让它发挥作用? 直接的方法是将 jpathwatch
我将 Neo4j 和 MongoDB 与 Grails 一起使用,我想知道 Maven Neo4j 插件是否也为我的构建提供了 Neo4j 依赖项。 MongoDB 也是如此。 我很困惑。我应该使用什
我正在尝试同时发布多个 Maven 项目,将它们部署到 oss.sonatype.org,然后将它们发布到 Maven Central。 我有一个构建 pom,用于一起构建多个多模块项目。构建 pom
我有一个带有 maven pom.xml 的项目 4.0.0 Minimal-J Minimal-J 0.1-SNAPSHOT Minimal-J
我需要制作一个下载maven项目并打印其依赖项的小程序 像这样: MavenArtifactRepository repository = new MavenArtifactRepository("t
我有一个关于 maven 在构建过程中如何计算类路径的问题。具体来说,控制何时使用“目标/类”以及何时使用来自存储库(本地/远程)的“jar”。 我有一个版本为 1.0.0-SNAPSHOT 的项目,
我有一个 maven 项目,需要在命令行(-Dmy.property=val)设置一个属性。 我需要做的是将该字符串转换为所有大写,因为该属性是 用于通过 maven-resources-plugin
引用和转义如何对传递给 Maven 插件的参数起作用? 例如,我想将多个文件名作为参数传递给 Maven Exec 插件运行的应用程序: mvnDebug exec:java -Dexec.mainC
我在父 pom 的导入的 dependencyManagement 部分中指定了一个库版本。我确认我的有效 pom 只有一次出现这种依赖。它在依赖管理部分: org.jav
我是一名优秀的程序员,十分优秀!