maven 中的插件不生效的排查方法

还是自己学艺不精,没空系统学习,也是边用边学,这里记录下。

感谢博主的文章:https://www.cnblogs.com/wxyidea/p/10276672.html

先说结论:

原因出在在

<build>

下使用pluginManagement配置plugins和直接配置plugins是不同的。

形如:

<build>
  <finalName>iot-kafkamsg</finalName>
  <pluginManagement>
    <plugins>
      <plugin>
        <groupId>org.apache.maven.plugins</groupId>
        <artifactId>maven-shade-plugin</artifactId>
        <version>2.4.1</version>
        <executions>
          <execution>
            <phase>package</phase>
            <goals>
              <goal>shade</goal>
            </goals>
            <configuration>
              <transformers>
                <transformer
                  implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
                  <mainClass>cn.wxyidea.KafkaMsgDemo</mainClass>
                </transformer>
                <transformer
                  implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                  <resource>META-INF/spring.handlers</resource>
                </transformer>
                <transformer
                  implementation="org.apache.maven.plugins.shade.resource.AppendingTransformer">
                  <resource>META-INF/spring.schemas</resource>
                </transformer>
              </transformers>
            </configuration>
          </execution>
        </executions>
      </plugin>
    </plugins>
  </pluginManagement>
</build>

 而直接使用plugins:

<build>
        <finalName>Dr</finalName>

        <plugins>

            <!-- 可执行jar 插件 -->
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-jar-plugin</artifactId>
                <version>2.6</version>
                <configuration>
                    <archive>
                        <manifest>
                            <addClasspath>true</addClasspath>
                            <classpathPrefix>lib/</classpathPrefix>
                            <mainClass>com.fulong.drs.controller.PressureTest</mainClass>
                        </manifest>
                    </archive>
                </configuration>
            </plugin>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-dependency-plugin</artifactId>
                <version>2.10</version>
                <executions>
                    <execution>
                        <id>copy-dependencies</id>
                        <phase>package</phase>
                        <goals>
                            <goal>copy-dependencies</goal>
                        </goals>
                        <configuration>
                            <outputDirectory>${project.build.directory}/lib</outputDirectory>
                        </configuration>
                    </execution>
                </executions>
            </plugin>

 

        </plugins>
    </build>

 区别是

  • pluginManagement是一种在项目的多个模块中共享相同插件配置的方法, 它旨在配置可以被其它模块继承的插件信息,即是对插件的声明,在pluginManagement中配置plugins,执行maven命令时,不会被maven加载。
    pluginManagement中声明的插件可以被当前pom或子pom中引用,比如你在项目的父pom中使用pluginManagement声明插件,那么在子pom中可以继承该插件,只需要在plugins节点中配置 groupId 和 artifactId就可以完成插件的引用。
  • plugins才是插件的实际调用,它可以自己定义plugin,也可以从父pom的pluginManagement中继承。

 ok了。

顺便记录下自己排查插件没有生效的方法:就是看maven运行命令时的日志,如图所示:

 

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
在 IntelliJ IDEA 使用 Maven Helper 插件可以帮助你解决 Maven 项目的依赖问题。以下是使用 Maven Helper 插件的步骤: 1. 安装插件:在 IntelliJ IDEA ,打开插件市场(File -> Settings -> Plugins),搜索 "Maven Helper",然后点击 "Install" 安装插件。 2. 打开 Maven Helper 工具窗口:点击底部的 "Maven Helper" 工具窗口按钮,或者选择 "View" -> "Tool Windows" -> "Maven Helper" 菜单来打开 Maven Helper 工具窗口。 3. 导入 Maven 项目:在 Maven Helper 工具窗口,点击 "+" 按钮,选择 "Import Maven Projects"。选择你的项目目录,并点击 "OK"。 4. 查看依赖树:在 Maven Helper 工具窗口,展开你的项目,找到 "Dependencies" 节点。点击 "Dependencies" 节点,将显示项目的依赖树结构。 5. 解决依赖冲突:在依赖树,你可以查看每个依赖项及其版本。如果存在依赖冲突,Maven Helper 会将冲突项标记为红色。你可以通过右键单击冲突项,选择 "Exclude This Artifact" 或 "Exclude This Artifact and Its Transitive Dependencies" 来解决冲突。 6. 查看依赖关系:在依赖树,你还可以查看每个依赖项的传递依赖关系。展开特定的依赖项,可以看到它所依赖的其他库和版本。 除了上述功能,Maven Helper 还提供了其他有用的功能,如显示冲突的依赖项、查找依赖项的冲突路径、检查重复的依赖项等。你可以通过点击 Maven Helper 工具窗口顶部的不同选项卡来访问这些功能。 请注意,具体的使用方法可能因插件版本和 IntelliJ IDEA 版本而有所不同。如果你遇到任何问题,可以参考 Maven Helper 插件的文档或搜索相关资源来获取更详细的指导。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值