Maven Shade плагин -Не удалось выполнить цель - PullRequest
0 голосов
/ 15 февраля 2019

Я пытался переименовать класс приложения Тика.Существуют конфликты загрузки из-за дублирования классов на пути к классам.Когда я пытаюсь запустить maven install -e, он выдает ошибку, и я хочу использовать класс

org.apache.tika

как

com.test1.tika

Файл 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.test1.tika</groupId>
  <artifactId>tika-app</artifactId>
  <version>0.0.1-SNAPSHOT</version>
  <packaging>jar</packaging>

  <name>tika-app</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>org.apache.tika</groupId>
        <artifactId>tika-app</artifactId>
        <version>1.20</version>
    </dependency>
  </dependencies>


  <build>
    <plugins>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-compiler-plugin</artifactId>
            <version>2.3</version>
            <configuration>
                <source>1.6</source>
                <target>1.6</target>
            </configuration>
        </plugin>
        <plugin>
            <groupId>org.apache.maven.plugins</groupId>
            <artifactId>maven-shade-plugin</artifactId>
            <version>2.3</version>
            <configuration>
                <createSourcesJar>true</createSourcesJar>
                <relocations>
                    <relocation>
                        <pattern>org.apache.tika.</pattern>
                        <shadedPattern>com.test1.tika.</shadedPattern>
                    </relocation>
                </relocations>
            </configuration>
            <executions>
                <execution>
                    <phase>package</phase>
                    <goals>
                        <goal>shade</goal>
                    </goals>
                </execution>
            </executions>
        </plugin>
    </plugins>
</build>

</project>

Ошибка команды mvn package следующая:

[ОШИБКА] Не удалось выполнить цель org.apache.maven.plugins: maven-shade-plugin: 2.3: shade (по умолчанию) в проекте tika-app: Ошибка создания затененной банки: null: IllegalArgumentException -> [Справка 1] org.apache.maven.lifecycle.LifecycleExecutionException: Не удалось выполнить цель org.apache.maven.plugins: maven-shade-plugin: 2.3: shade (по умолчанию) в проекте tika-app: Ошибка при создании затененного фляги: пусто приorg.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:215) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:156) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:148) на org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:117) по адресу org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:81) по адресу org.apache.maven.adedderThrerererebuild (SingleThreadedBuilder.java:56) в org.apache.maven.lifecycle.internal.LifecycleStarter.execute (LifecycleStarter.java:128) в org.apache.maven.DefaultMaven.doExecute (DefaultMaven.java:305) в org.apache.maven.DefaultMaven.doExecute (DefaultMaven.java:192) в org.apache.maven.DefaultMaven.execute (DefaultMaven.java:105) в org.apache.maven.cli.MavenCli.execute (MavenCli.java:956) вorg.apache.maven.cli.MavenCli.doMain (MavenCli.java:288) в org.apache.maven.cli.MavenCli.main (MavenCli.java:192) в sun.reflect.NativeMethodAccessorImpl.invoke0 (собственный метод) вsun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:62) в sun.reflect.DelegatingMethodAccessorImpl.invoke (DelegatingMethodAccessorImpl.java: 43) в java.lang.reflect.Method.invoke (Method.java:498) в org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced (Launcher.java:289) в org.codehaus.plexus.classworlds.launcher.Launcher.launch (Launcher.java:229) в org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode (Launcher.java:415) в org.codehaus.plexus.classworlds.launcher.Launcher.main (.java: 356) Вызвано: org.apache.maven.plugin.MojoExecutionException: Ошибка при создании затененного баночка: пусто в org.apache.maven.plugins.shade.mojo.ShadeMojo.execute (ShadeMojo.java:566) в орг.apache.maven.plugin.DefaultBuildPluginManager.executeMojo (DefaultBuildPluginManager.java:137) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:210) в org.apache.External.o.lifeвыполнить (MojoExecutor.java:156) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:148) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:117) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:81) в org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBilder.uilder.uilder.56) в org.apache.maven.lifecycle.internal.LifecycleStarter.execute (LifecycleStarter.java:128) в org.apache.maven.DefaultMaven.doExecute (DefaultMaven.java:305) в org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:192) в org.apache.maven.DefaultMaven.execute (DefaultMaven.java:105)в org.apache.maven.cli.MavenCli.execute (MavenCli.java:956) в org.apache.maven.cli.MavenCli.doMain (MavenCli.java:288) в org.apache.maven.cli.MavenCli.main(MavenCli.java:192) в sun.reflect.NativeMethodAccessorImpl.invoke0 (родной метод) в sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:62) в sun.reflect.DelegatingImpotjava.lang.reflect.Method.invoke (Method.java:498) в org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced (Launcher.java:289) в org.codehaus.plexus.classworlds.launcher.Launcher.запуск (Launcher.java:229) в org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode (Launcher.java:415) в org.codehaus.plexus.classworlds.launcher.Launcher.main (Launcher.java:356)Вызывается: java.lang.IllegalArgumentException at org.objectweb.asm.ClassReader.(Неизвестный источник) на org.objectweb.asm.ClassReader.(Неизвестный источник) на org.objectweb.asm.ClassReader.(Неизвестный источник) в org.apache.maven.plugins.shade.DefaultShader.addRemappedClass (DefaultShader.java:331) в org.apache.maven.plugins.shade.DefaultShader.shade (DefaultShader.java:165) в org.apache.maven.plugins.shade.mojo.ShadeMojo.execute (ShadeMojo.java:471) в org.apache.maven.plugin.DefaultBuildPluginManager.executeMojo (DefaultBuildPluginManager.java:137) в org.joo..execute (MojoExecutor.java:210) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:156) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:148) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:117) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java.achemaache at at.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build (SingleThreadedBuilder.java:56) в org.apache.maven.lifecycle.internal.LifecycleStarter.execute (LifecycleStarter.java:128) в org.apache.maven.DefaultMaven.doExecute (DefaultMaven.java:305) в org.apache.maven.DefaultMaven.doExecute (DefaultMaven.java:192) в org.apache.maven.DefaultMaven.execute (DefaultMaven.java:105) в org.apache.maven.cli.MavenCli.execute (MavenCli.java:956) в org.apache.maven.cli.MavenCli.doMain (MavenCli.java:288) вorg.apache.maven.cli.MavenCli.main (MavenCli.java:192) в sun.reflect.NativeMethodAccessorImpl.invoke0 (собственный метод) в sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessref.jpg).DelegatingMethodAccessorImpl.invoke (DelegatingMethodAccessorImpl.java:43) в java.lang.reflect.Method.invoke (Method.java:498) в org.codehaus.plexus.classworlds.launcher.Launcher.launchEnh):.codehaus.plexus.classworlds.launcher.Launcher.launch (Launcher.java:229) в org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode (Launcher.java:415) в org.codehaus.plexus.classworlds.launcher.Launcher.main (Launcher.java:356) [ОШИБКА] [ОШИБКА] Перезапустите Maven, используя ключ -X, чтобы включить полное ведение журнала отладки.[ОШИБКА] [ОШИБКА] Для получения дополнительной информации об ошибках и возможных решениях, пожалуйста, прочитайте следующие статьи: [ОШИБКА] [Справка 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoExecutionException

1 Ответ

0 голосов
/ 15 февраля 2019

Изменение версии maven-compiler-plugin с 2.3 на 3.2.1 решило эту проблему.

...