Перепаковка Spring-Boot-Maven-плагин, не включая зависимости
Вот мой pom.xml:
<groupId>com.securebort.services</groupId>
<artifactId>services</artifactId>
<version>0.0.2</version>
<packaging>jar</packaging>
<name>services</name>
<description>Cipherworks services exposed to the client applications</description>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.0.4.RELEASE</version>
<relativePath/>
</parent>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<maven.compiler.source>${java.version}</maven.compiler.source>
<maven.compiler.target>${java.version}</maven.compiler.target>
<maven.build.timestamp.format>yyyyMMddHHmmss</maven.build.timestamp.format>
<beanstalk.versionLabel>${maven.build.timestamp}</beanstalk.versionLabel>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-validator</artifactId>
</exclusion>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.apache.tomcat</groupId>
<artifactId>tomcat-jdbc</artifactId>
<version>9.0.1</version>
</dependency>
<dependency>
<groupId>com.cipherworks</groupId>
<artifactId>cwcommon</artifactId>
<version>0.0.1</version>
</dependency>
<dependency>
<groupId>securebort</groupId>
<artifactId>datacrypt</artifactId>
<version>0.0.1</version>
</dependency>
<dependency>
<groupId>com.cwkit</groupId>
<artifactId>cwkit</artifactId>
<version>0.0.1</version>
</dependency>
<dependency>
<groupId>com.cipherworks</groupId>
<artifactId>iam</artifactId>
<version>0.0.1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.6</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<version>2.0.4.RELEASE</version>
<configuration>
<layout>JAR</layout>
<mainClass>com.cipherworks.services.ServicesApplication</mainClass>
</configuration>
<executions>
<execution>
<goals>
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
Когда я делаю пакет MVN, он создает перепакованный файл JAR. Но перепакованная банка не содержит моих зависимостей cwcommon, datacrypt и cwkit. Я проверил мой локальный репозиторий, и в нем есть все мои зависимые файлы JAR. По какой-то причине они не попадают в жирную банку.
Вывод зависимости цели: tree: я не смог скопировать и вставить все выходные данные из-за ограничения размера при переполнении стека. Я только скопировал разделы, которые имеют мои зависимости.
....
....
....
[DEBUG] Using local repository at C:\Users\CipherWorks\.m2\repository
[DEBUG] Using manager EnhancedLocalRepositoryManager with priority 10.0 for C:\Users\CipherWorks\.m2\repository
[INFO] Scanning for projects...
[DEBUG] Extension realms for project com.securebort.services:services:jar:0.0.2: (none)
[DEBUG] Looking up lifecyle mappings for packaging jar from ClassRealm[plexus.core, parent: null]
[DEBUG] Extension realms for project org.springframework.boot:spring-boot-starter-parent:pom:2.0.4.RELEASE: (none)
[DEBUG] Looking up lifecyle mappings for packaging pom from ClassRealm[plexus.core, parent: null]
[DEBUG] Extension realms for project org.springframework.boot:spring-boot-dependencies:pom:2.0.4.RELEASE: (none)
[DEBUG] Looking up lifecyle mappings for packaging pom from ClassRealm[plexus.core, parent: null]
[DEBUG] Resolving plugin prefix dependency from [org.apache.maven.plugins, org.codehaus.mojo]
[DEBUG] Resolved plugin prefix dependency to org.apache.maven.plugins:maven-dependency-plugin from POM com.securebort.services:services:jar:0.0.2
[DEBUG] === REACTOR BUILD PLAN ================================================
[DEBUG] Project: com.securebort.services:services:jar:0.0.2
[DEBUG] Tasks: [dependency:tree]
[DEBUG] Style: Regular
[DEBUG] =======================================================================
[INFO]
[INFO] ------------------------------------------------------------------------
[INFO] Building services 0.0.2
....
....
....
[DEBUG] Lifecycle clean -> [pre-clean, clean, post-clean]
[DEBUG] Lifecycle site -> [pre-site, site, post-site, site-deploy]
[DEBUG] === PROJECT BUILD PLAN ================================================
[DEBUG] Project: com.securebort.services:services:0.0.2
....
....
[DEBUG] org.apache.tomcat.embed:tomcat-embed-core:jar:8.5.32:provided
[DEBUG] org.apache.tomcat.embed:tomcat-embed-el:jar:8.5.32:provided
[DEBUG] org.apache.tomcat.embed:tomcat-embed-websocket:jar:8.5.32:provided
[DEBUG] org.apache.tomcat:tomcat-jdbc:jar:9.0.1:compile
[DEBUG] org.apache.tomcat:tomcat-juli:jar:9.0.1:compile
[DEBUG] com.cipherworks:cwcommon:jar:0.0.1:compile
[DEBUG] securebort:datacrypt:jar:0.0.1:compile
[DEBUG] com.cwkit:cwkit:jar:0.0.1:compile
[DEBUG] com.google.code.gson:gson:jar:2.8.5:compile (version managed from 2.6.2 by org.springframework.boot:spring-boot-dependencies:2.0.4.RELEASE)
[DEBUG] org.slf4j:slf4j-api:jar:1.7.25:compile (version managed from 1.7.24 by org.springframework.boot:spring-boot-dependencies:2.0.4.RELEASE)
[DEBUG] com.fasterxml.jackson.dataformat:jackson-dataformat-xml:jar:2.9.6:compile (version managed from 2.9.5 by com.fasterxml.jackson:jackson-bom:2.9.6)
[DEBUG] com.fasterxml.jackson.core:jackson-core:jar:2.9.6:compile
....
....
[DEBUG] org.codehaus.woodstox:stax2-api:jar:3.1.4:compile
[DEBUG] com.fasterxml.woodstox:woodstox-core:jar:5.0.3:compile
[DEBUG] com.cipherworks:iam:jar:0.0.1:compile
[DEBUG] com.amazonaws:aws-java-sdk:jar:1.11.396:compile
[DEBUG] com.amazonaws:aws-java-sdk-dlm:jar:1.11.396:compile
.....
.....
[DEBUG] (f) outputType = text
[DEBUG] (f) project = MavenProject: com.securebort.services:services:0.0.2 @ C:\git\services\pom.xml
[DEBUG] (f) reactorProjects = [MavenProject: com.securebort.services:services:0.0.2 @ C:\git\services\pom.xml]
[DEBUG] (f) session = org.apache.maven.execution.MavenSession@3872bc37
...
...
[DEBUG] org.apache.tomcat.embed:tomcat-embed-el:jar:8.5.32:provided
[DEBUG] org.apache.tomcat.embed:tomcat-embed-websocket:jar:8.5.32:provided
[DEBUG] org.apache.tomcat:tomcat-jdbc:jar:9.0.1:compile
[DEBUG] org.apache.tomcat:tomcat-juli:jar:9.0.1:compile
[DEBUG] com.cipherworks:cwcommon:jar:0.0.1:compile
[DEBUG] securebort:datacrypt:jar:0.0.1:compile
[DEBUG] com.cwkit:cwkit:jar:0.0.1:compile
[DEBUG] com.google.code.gson:gson:jar:2.8.5:compile (version managed from 2.6.2 by org.springframework.boot:spring-boot-dependencies:2.0.4.RELEASE)
...
...
[DEBUG] com.fasterxml.jackson.module:jackson-module-jaxb-annotations:jar:2.9.6:compile
[DEBUG] org.codehaus.woodstox:stax2-api:jar:3.1.4:compile
[DEBUG] com.fasterxml.woodstox:woodstox-core:jar:5.0.3:compile
[DEBUG] com.cipherworks:iam:jar:0.0.1:compile
[DEBUG] com.amazonaws:aws-java-sdk:jar:1.11.396:compile
[DEBUG] com.amazonaws:aws-java-sdk-dlm:jar:1.11.396:compile
...
...
[INFO] | +- org.apache.tomcat.embed:tomcat-embed-el:jar:8.5.32:provided
[INFO] | \- org.apache.tomcat.embed:tomcat-embed-websocket:jar:8.5.32:provided
[INFO] +- org.apache.tomcat:tomcat-jdbc:jar:9.0.1:compile
[INFO] | \- org.apache.tomcat:tomcat-juli:jar:9.0.1:compile
[INFO] +- com.cipherworks:cwcommon:jar:0.0.1:compile
[INFO] +- securebort:datacrypt:jar:0.0.1:compile
[INFO] +- com.cwkit:cwkit:jar:0.0.1:compile
[INFO] | +- com.google.code.gson:gson:jar:2.8.5:compile
[INFO] | +- org.slf4j:slf4j-api:jar:1.7.25:compile
...
...
Мои зависимости (cwkit, cwcommon, datacrypt, iam) отображаются в выходных данных INFO. Но они не попадают в жирную банку.
2 ответа
К сожалению, на самом деле недостаточно информации, чтобы сказать, почему банки не включены. Единственное свойство, которое может повлиять на вещи excludes
и похоже, что это не установлено в вашем POM.
Я предполагаю, что вы не можете поделиться полным проектом, и вы не смогли повторить проблему в меньшем образце. Единственный оставленный вариант - отладить плагин самостоятельно. Вот как вы можете сделать это.
1) Извлеките базу кода Spring Boot в маркированной версии, которую вы используете в своем POM-файле:
$ git clone https://github.com/spring-projects/spring-boot.git
$ cd spring-boot
$ git fetch --tags
$ git checkout v2.0.4.RELEASE
2) импортировать spring-boot-maven-plugin
а также spring-boot-loader-tools
в вашу любимую IDE.
Вы должны быть в состоянии импортировать только этот проект. На самом деле не имеет значения, не скомпилируется ли он, поскольку нам просто нужно запустить удаленный отладчик и установить его в код.
3) Запустите сборку Maven, используя mvnDebug
Для этого вам необходимо установить полную версию Maven.
$ cd ~/myproject
$ mvnDebug package
4) Подключите удаленный отладчик
Maven должен вывести что-то вроде этого:
Preparing to execute Maven in debug mode
Listening for transport dt_socket at address: 8000
Вернитесь в свою среду IDE и добавьте точку останова здесь перед началом сеанса удаленной отладки на порту 8000.
5) Отладка
Теперь вы можете войти в код и посмотреть, что происходит. Вы определенно захотите посмотреть Repackager, чтобы увидеть, пишутся ли библиотеки. Одной из возможных причин вашей проблемы является то, что isZip
метод возвращает false
, Проверьте результат этого метода и посмотрите, действительно ли в ваших библиотеках допустимы zip-файлы?
Когда я добавил maven.test.skip = true в свойствах pom.xml, проблема исчезла. Спасибо за полезные советы.