我们有几个遗留的Java项目,我们将其转换为Maven项目/模块。以前,所有项目都是NetBeans项目,没有真实的的依赖关系管理。外部依赖关系存在于公司的网络驱动器上,并作为JAR直接包含在每个模块的NetBeans项目中。对于内部依赖关系,使用了简单的项目引用。构建所有东西是一件痛苦的事,因为程序员必须按照正确的顺序构建所有东西。
现在,我们可以在IntelliJ IDEA和NetBeans中打开所有的Maven模块。但是,我很难找到以特定方式合并不同模块和外部依赖项的最佳方法,这种方式符合内部插件式结构。特别是在NetBeans中(必须可以同时使用这两种IDE进行开发)。
下面是git仓库/项目结构的大概样子。模块的文件夹结构是每个模块的默认Maven结构。这个站点的列表功能太笨拙了,所以我把它作为截图包括进来。
我们有一个内部的maven存储库,用maven等构建的东西正在工作。对于Intellij IDEA,我可以通过自定义运行配置为customer 1运行和调试最终产品,该配置将所需文件复制到所需结构中:
使用IntelliJ IDEA,我可以调试软件,但我认为这种方法(我创建的自定义IntelliJ运行配置,直接指向所有需要的JAR和文件)相当丑陋,而且对于NetBeans,我找不到类似的“运行配置”机制。
因此,我尝试通过创建一个新的“Customer 1 Runnable”Maven项目来实现这个构建过程,作为一种构建描述,它指向所有需要的Maven模块。基于此,我相信我可以实现和自动创建所需的软件结构。因此,使用maven-assembly-plugin,将所有模块复制到一个plugin文件夹中,并将模块的所有依赖项复制到Customer 1 Runnable项目内的lib文件夹中。
首先,我的假设是正确的,这是一个可能的maven组装插件用例?
项目本身没有任何源文件,只有一个pom.xml和assembly-config.xml描述符。我将assembly-plugin附加到了package阶段。当运行mvn package
命令时,所有连接的模块都被构建,但是对于assembly-plugin的执行,我得到了以下输出:
对于初学者,我只尝试在程序集描述符中包含一个模块,这是它的XML(opicom-assembly.xml):
<assembly xmlns="http://maven.apache.org/ASSEMBLY/2.1.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/ASSEMBLY/2.1.0 http://maven.apache.org/xsd/assembly-2.1.0.xsd">
<id>opicom-assembly</id>
<formats>
<format>dir</format>
</formats>
<includeBaseDirectory>false</includeBaseDirectory>
<moduleSets>
<moduleSet>
<useAllReactorProjects>true</useAllReactorProjects>
<includes>
<include>my.company.reporting:module1</include>
</includes>
</moduleSet>
</moduleSets>
</assembly>
Customer 1可运行项目的pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<version>1.6</version>
<groupId>my.company.customer1</groupId>
<artifactId>OpicomRunnable</artifactId>
<packaging>pom</packaging>
<name>OpicomRunnable</name>
<repositories>
<repository>
<id>Company-Maven-Repo</id>
<url>file:\\\\MyCompany\TFSDrop\MavenRepo</url>
</repository>
</repositories>
<modules>
<module>../my.company.customer1.module1</module>
<module>../my.company.customer1.module2</module>
.
.
.
<module>../../MyCompany_Common/Report/my.company.reporting.module1</module>
</modules>
<build>
<plugins>
<plugin>
<artifactId>maven-assembly-plugin</artifactId>
<version>3.3.0</version>
<inherited>true</inherited>
<executions>
<execution>
<id>copy-dependencies</id>
<phase>package</phase>
<goals>
<goal>single</goal>
</goals>
</execution>
</executions>
<configuration>
<descriptors>
<descriptor>opicom-assembly.xml</descriptor>
</descriptors>
</configuration>
</plugin>
</plugins>
</build>
</project>
模块的pom如下所示:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>my.company</groupId>
<artifactId>reporting</artifactId>
<version>1.3</version>
<relativePath>../pom.xml</relativePath>
</parent>
<artifactId>module1</artifactId>
<version>1.3</version>
<packaging>jar</packaging>
<dependencies>
<!-- external dependencies -->
<dependency>
<groupId>commons-pool</groupId>
<artifactId>commons-pool</artifactId>
<version>1.6</version>
</dependency>
<dependency>
<groupId>com.oracle.database.jdbc</groupId>
<artifactId>ojdbc8</artifactId>
<version>21.1.0.0</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-assembly-plugin</artifactId>
<version>3.3.0</version>
<configuration>
<finalName>my-company-${project.artifactId}</finalName>
<appendAssemblyId>false</appendAssemblyId>
<outputDirectory>../build</outputDirectory>
<descriptorRefs>
<descriptorRef>jar-with-dependencies</descriptorRef>
</descriptorRefs>
</configuration>
</plugin>
</plugins>
</build>
</project>
感谢您对我在这里做错了什么/如何用Maven实现这一点的任何输入。
**EDIT:**按照要求,这里是一个ZIP-File. https://drive.google.com/drive/folders/1ilJeTrOPgYgUTdOP0J4BQcBnPT5fls0k?usp=sharing的示例项目。父目录ModuleGroupCustomer和ModuleGroupCommon确实代表了真实的场景中的git仓库。相对模块路径是造成的,因为应该是我的“运行配置”的maven项目指向了两个仓库中的maven项目。
也许我误解了Maven的总体含义?我认为它是类似于.Net nuget包的依赖项管理用例,但也像普通NetBeans/Intellij项目一样作为“项目配置”。
在日常开发中,简单地使用现有的NetBeans项目是否更好?
1条答案
按热度按时间l5tcr1uw1#
经过漫长而乏味的尝试和错误的过程,我找到了一个适合我的解决方案。所以我决定在线分享这个解决方案,以防其他人遇到类似的问题。这里有一个包含工作示例项目的最终zip存档的链接=〉File CustomerRunnable_RunningAssemblyPluginStackoverflowExample.zip https://drive.google.com/drive/u/0/folders/1ilJeTrOPgYgUTdOP0J4BQcBnPT5fls0k
我的错误是我误解了汇编插件的工作原理。我在聚合器pom(CustommerRunnable)中执行插件的方法是错误的,因为这个maven项目只作为父pom存在。
CustommerRunnable pom.xml将所有客户插件作为模块引用。这些模块没有CustommerRunnable作为父模块,而是有一个不同的pom。然后我创建了一个单独的maven项目“distribution”。(需要customer maven模块)作为依赖项.它还具有CustommerRunnable pom.xml作为父项.因此,当我在NetBeans中运行项目时,所有连接的模块也被构建(如果需要)。
它还配置汇编插件。汇编插件附加到maven package-phase并因此与它一起执行。它还使用自定义汇编描述符,这将把所有以前定义的插件复制到正确的文件夹中。这是通过使用包含和排除模式的dependencySet来完成的。有关这方面的详细信息,请参见https://maven.apache.org/plugins/maven-assembly-plugin/advanced-descriptor-topics.html。因此,一个dependencySet将所有插件的所有jar文件复制到一个/plugin文件夹,然后反过来将所有外部依赖的jar文件复制到/lib文件夹。
描述符还定义了一些额外的文件,以便复制到特定的位置。exec-maven-plugin,这样我就可以轻松地从NetBeans中启动客户软件了。我还没有成功地根据所需的类路径参数正确配置执行插件。
最终结果如下所示:
同样值得注意的是,NetBeans内部的“构建项目”、“运行项目”和“调试项目”的配置需要进行一点修改。(右键单击模块“分发”-〉“属性”-〉指向“操作”