Spotify Docker/ Dockerfile Maven плагин [ОШИБКА] Копирование не удалось
Я пытаюсь выполнить mvn clean package docker:build
в моем проекте это терпит неудачу со следующей ошибкой
ОШИБКА] Не удалось выполнить цель com.spotify:docker-maven-plugin:1.1.0: сборка (default-cli) в проекте mma-access-management-auth-server: Обнаружено исключение: ошибка COPY: stat /var/lib/docker/tmp/docker-builder181535370/mma-access-management-app-1.0.0-SNAPSHOT.jar: нет такого файла или каталога -> [Help 1] org.apache.maven.lifecycle.LifecycleExecutionException: не удалось выполнить цель com.spotify:docker-maven-plugin:1.1.0: сборка (default-cli) для проекта mma-access-management-auth-server: исключение, обнаруженное в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor. Java:213) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:154) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:146) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:117) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:81) в org.apache.cycle. ernal.builder.singlethreaded.SingleThreadedBuilder.build (SingleThreadedBuilder.java:51) по адресу org.apache.maven.lifecycle.internal.LifecycleStarter.execute (LifecycleStarter.java:128) по адресу org.apache.maven.DefaultMaven.MefExte (Java:309) в org.apache.maven.DefaultMaven.doExecute (DefaultMaven.java:194) в org.apache.maven.DefaultMaven.execute (DefaultMaven.java:107) в org.apache.maven.cli.MavenCli.execute (MavenCli.java:955) в org.apache.maven.cli.MavenCli.doMain (MavenCli.java:290) в org.apache.maven.cli.MavenCli.main (MavenCli.java:194) в sun.reflect.NativeMethodAccessorImpl.invoke0 (собственный метод) в sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:62) в sun.reflect.DelegatingMethodAccessorImpl.invoke (methodava.jho.jj Java:498) в org.codehaus.plexus.classworlds.launcher.Launcher.launchEnhanced (Launcher.java:289) в org.codehaus.plexus.classworlds.launcher.Launcher.launch (Лау ncher.java:229) в org.codehaus.plexus.classworlds.launcher.Launcher.mainWithExitCode (Launcher.java:415) в org.codehaus.plexus.classworlds.launcher.Launcher.main (Launcher.java:356), вызванный: org.apache.maven.plugin.MojoExecutionException: Исключение, захваченное в com.spotify.docker.AbstractDockerMojo.execute (AbstractDockerMojo.java:151) в com.spotify.docker.BuildMojo.execute (BuildMojo.java:324) в орг.apache.maven.plugin.DefaultBuildPluginManager.executeMojo (DefaultBuildPluginManager.java:134) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:208) в org.apache.External.cycle. выполнить (MojoExecutor.java:154) в org.apache.maven.lifecycle.internal.MojoExecutor.execute (MojoExecutor.java:146) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java) в org.apache.maven.lifecycle.internal.LifecycleModuleBuilder.buildProject (LifecycleModuleBuilder.java:81) в org.apache.maven.lifecycle.internal.builder.singlethreaded.SingleThreadedBuilder.build (SingleThreadedBuilder.java:51) в org.apache.maven.lifecycle.internal.LifecycleStarter.execute (LifecycleStarter.java:128) в org.apache.maven.DefaultMaven.MoExtete.java:309) в org.apache.maven.DefaultMaven.doExecute (DefaultMaven.java:194) в org.apache.maven.DefaultMaven.execute (DefaultMaven.java:107) в org.apache.maven.cli.MavenCli. выполнить (MavenCli.java:955) в org.apache.maven.cli.MavenCli.doMain (MavenCli.java:290) в org.apache.maven.cli.MavenCli.main (MavenCli.java:194) в sun.reflect.NativeMethodAccessorImpl.invoke0 (нативный метод) в sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:62) в sun.reflect.DelegatingMethodAccessorImpl.invoke (DelegavaMetho.rej.rej.rej.ref.jj.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 (Launcher.java:356) Причиненный by: com.spotify.docker.client.exceptions.DockerException: COPY не удалось: stat /var/lib/docker/tmp/docker-builder181535370/mma-access-management-app-1.0.0-SNAPSHOT.jar: такого файла нет или каталог
Это мой 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>
<parent>
<groupId>com.mma</groupId>
<artifactId>mma-access-management-parent</artifactId>
<version>1.0.0-SNAPSHOT</version>
</parent>
<artifactId>mma-access-management-auth-server</artifactId>
<packaging>jar</packaging>
<dependencies>
<dependency>
<groupId>${project.groupId}</groupId>
<artifactId>mma-access-management-rest-api</artifactId>
<version>${project.version}</version>
</dependency>
</dependencies>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.source>1.8</maven.compiler.source>
<maven.compiler.target>1.8</maven.compiler.target>
</properties>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>1.5.8.RELEASE</version>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.1.0</version>
<configuration>
<imageName>mma/${project.artifactId}</imageName>
<imageTags>
<imageTag>${project.version}</imageTag>
<imageTag>latest</imageTag>
</imageTags>
<dockerDirectory>dockerfile</dockerDirectory>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
</plugins>
</build>
Это мой Dockerfile
FROM openjdk:8u131-jdk-alpine
ENV targetDir /usr/local/access-management-app-1.0.0-SNAPSHOT.jar
ENV srcDir .
ENV jarFile mma-access-management-app-1.0.0-SNAPSHOT.jar
RUN mkdir ${targetDir}
COPY ${srcDir}/${jarFile} ${targetDir}
WORKDIR ${targetDir}
CMD ["java", "-jar", "mma-access-management-app-1.0.0-SNAPSHOT.jar"]
EXPOSE 8080/tcp
Я не знаю, что идет не так. Я также попытался использовать плагин dockerfile от spotify, который также не удался.
2 ответа
JAR-файл сборки maven ${project.build.finalName}.jar
отличается от того, который вы определили в Dockerfile
,
Настройте указанное имя файла jar в Dockerfile, чтобы оно соответствовало jar сборки maven, и оно будет работать.
FROM openjdk:8u131-jdk-alpine
ENV targetDir /usr/local/access-management-auth-server-1.0.0-SNAPSHOT.jar
ENV srcDir .
ENV jarFile mma-access-management-auth-server-1.0.0-SNAPSHOT.jar
RUN mkdir ${targetDir}
COPY ${srcDir}/${jarFile} ${targetDir}
WORKDIR ${targetDir}
CMD ["java", "-jar", "mma-access-management-auth-server-1.0.0-SNAPSHOT.jar"]
EXPOSE 8080/tcp
Не похоже на проблему с плагином spotify. Сбой сборки докера
COPY ${srcDir}/${jarFile} ${targetDir}
Я думаю, srcDir
указывает на src
папка, в то время как банка будет присутствовать в target
папка.