netbeans 如何使一个类似插件的架构可运行?

shyt4zoc  于 2022-11-10  发布在  其他
关注(0)|答案(1)|浏览(196)

我们有几个遗留的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项目是否更好?

l5tcr1uw

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内部的“构建项目”、“运行项目”和“调试项目”的配置需要进行一点修改。(右键单击模块“分发”-〉“属性”-〉指向“操作”

相关问题