Maven shade plugin предупреждение: у нас есть дубликат-как исправить?
Это мой проект POM (ссылка на вставить, поэтому вы можете щелкнуть правой кнопкой мыши > сохранить как pom.в XML)
<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>
<groupId>com.zybnet</groupId>
<artifactId>excel-reporter</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>jar</packaging>
<name>mvn1</name>
<url>http://maven.apache.org</url>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>3.8.1</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.8</version>
</dependency>
<dependency>
<groupId>net.sf.jasperreports</groupId>
<artifactId>jasperreports</artifactId>
<version>4.6.0</version>
</dependency>
<dependency>
<groupId>org.codehaus.groovy</groupId>
<artifactId>groovy-all</artifactId>
<version>2.0.0</version>
</dependency>
</dependencies>
<build>
<resources>
<resource>
<directory>${project.build.sourceDirectory}</directory>
</resource>
</resources>
<plugins>
<plugin>
<artifactId>maven-jar-plugin</artifactId>
<configuration>
<finalName>${artifactId}-${version}-tmp</finalName>
</configuration>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-shade-plugin</artifactId>
<version>1.7.1</version>
<executions>
<execution>
<phase>package</phase>
<goals>
<goal>shade</goal>
</goals>
<configuration>
<filters>
<filter>
<artifact>*:*</artifact>
<excludes>
<exclude>META-INF/*.SF</exclude>
<exclude>META-INF/*.DSA</exclude>
<exclude>META-INF/*.RSA</exclude>
</excludes>
</filter>
</filters>
<transformers>
<transformer
implementation="org.apache.maven.plugins.shade.resource.ManifestResourceTransformer">
<mainClass>com.zybnet.Main</mainClass>
</transformer>
</transformers>
</configuration>
</execution>
</executions>
</plugin>
</plugins>
</build>
</project>
я последовал совету настройки плагина jar по умолчанию, как рекламируется в FAQ, но все же, когда я бегу mvn package
о предупреждениях 20K выданы. Бег!--2--> не помогло.
По данным ответ, я мог бы вручную исключить некоторые зависимости. Тем не менее, я не знаю, правильно ли это, и дерево зависимостей довольно сложное, поэтому трудно спорить, с чего начать.
Я знаю, что эти проблемы не вредны, но я привык относиться к предупреждениям как к чему-то, что должно быть исправлено. Более того, я новичок в Maven, поэтому я хотел бы понять, что не так с моим пониманием и как устранить проблемы.
(использование плагина сборки maven здесь не является опцией)
2 ответов
иногда случается, что одно и то же определение класса находится в двух или более файлах JAR (обычно это банки зависимостей). В таком случае разработчик ничего не может сделать, кроме как попытаться выяснить, что вручную исключить из зависимостей или из конечного артефакта (возможно, с помощью mvn dependency:tree -Ddetail=true
). Я!--5-->открыл проблему и отправил патч, чтобы помочь разработчику с немного более красивым выходом, как
[WARNING] xml-apis-1.3.02.jar, xmlbeans-2.3.0.jar define 4 overlappping classes:
[WARNING] - org.w3c.dom.TypeInfo
[WARNING] - org.w3c.dom.DOMConfiguration
[WARNING] - org.w3c.dom.DOMStringList
[WARNING] - org.w3c.dom.UserDataHandler
[WARNING] maven-shade-plugin has detected that some .class files
[WARNING] are present in two or more JARs. When this happens, only
[WARNING] one single version of the class is copied in the uberjar.
[WARNING] Usually this is not harmful and you can skip these
[WARNING] warnings, otherwise try to manually exclude artifacts
[WARNING] based on mvn dependency:tree -Ddetail=true and the above
[WARNING] output
[WARNING] See http://docs.codehaus.org/display/MAVENUSER/Shade+Plugin
использование этого вывода и этого из mvn dependency:tree
я добавил разделы как
<dependency>
<groupId>net.sf.jasperreports</groupId>
<artifactId>jasperreports</artifactId>
<version>4.7.0</version>
<exclusions>
<exclusion>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
</exclusion>
<exclusion>
<groupId>bouncycastle</groupId>
<artifactId>bcmail-jdk14</artifactId>
</exclusion>
<exclusion>
<groupId>bouncycastle</groupId>
<artifactId>bcprov-jdk14</artifactId>
</exclusion>
<exclusion>
<groupId>org.bouncycastle</groupId>
<artifactId>bctsp-jdk14</artifactId>
</exclusion>
</exclusions>
</dependency>
и удалось сократить количество предупреждений с нескольких тысяч до нескольких десятков. И все же это не идеально. Тем не менее, они продолжают копировать классы, которые приводят к столкновениям имен (я не могу понять, почему). Тем не менее, это решение специфично для этого конкретного проекта и не может быть легко перенесено на что-либо еще.
в качестве нового обновления этой проблемы обновляется текущий плагин maven. Вопрос заключается в использовании
<version>1.7.1</version>
который только скажет вам, что вы:
We have a duplicate org/eclipse/persistence/internal/libraries/asm/AnnotationVisitor.class in /Users/.../repository/org/eclipse/persistence/eclipselink/2.7.0/eclipselink-2.7.0.jar
оставляя вам угадать или проб и ошибок, где первая запись, где у вас есть перекрывающиеся классы. Не очень полезный. Fortunatly,
<version>3.1.0</version>
даст вам более полезный выход, который включает в себя банки, откуда они пришли: например,
annotations-3.0.1.jar, jcip-annotations-1.0.jar define 4 overlapping classes:
- net.jcip.annotations.GuardedBy
- net.jcip.annotations.NotThreadSafe
...
затем вы можете решить, чтобы исключить один или другой, или используйте shade для переименования классов в соответствии с вашим проектом.