maven Compilation failed [JDK20 MAVEN3.9.2 ] javax.annotation.processing.Processor: Provider org.mapstruct.extensions.spring.converter.ConverterMapperProcessor could not be instantiated
iqolome opened this issue · comments
iqolome commented
environment
Java and Maven information
C:Usersqolom>java -version
java version "20.0.1" 2023-04-18
Java(TM) SE Runtime Environment (build 20.0.1+9-29)
Java HotSpot(TM) 64-Bit Server VM (build 20.0.1+9-29, mixed mode, sharing)
C:Usersqolom>mvn -v
Apache Maven 3.9.2 (c9616018c7a021c1c39be70fb2843d6f5f9b8a1c)
Maven home: D:Serverapache-maven-3.9.2
Java version: 20.0.1, vendor: Oracle Corporation, runtime: C:Program FilesJavajdk-20
Default locale: zh_CN, platform encoding: UTF-8
OS name: "windows 11", version: "10.0", arch: "amd64", family: "windows"
pom information
<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>
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-parent -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>3.1.0</version>
<relativePath/>
<!-- lookup parent from repository -->
</parent>
<properties>
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<lombok.version>1.18.28</lombok.version>
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok-mapstruct-binding -->
<lombok-mapstruct-binding.version>0.2.0</lombok-mapstruct-binding.version>
<!-- https://mvnrepository.com/artifact/org.mapstruct/mapstruct -->
<mapstruct.version>1.5.5.Final</mapstruct.version>
<!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-annotations -->
<mapstruct-spring-annotations.version>1.0.1</mapstruct-spring-annotations.version>
<!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-extensions -->
<mapstruct-spring-extensions.version>1.0.1</mapstruct-spring-extensions.version>
<!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-dependencies -->
<spring-cloud-dependencies.version>2022.0.3</spring-cloud-dependencies.version>
</properties>
<dependencies>
<dependency>
<groupId>org.mapstruct</groupId>
<artifactId>mapstruct</artifactId>
<version>${mapstruct.version}</version>
</dependency>
<dependency>
<groupId>org.mapstruct.extensions.spring</groupId>
<artifactId>mapstruct-spring-extensions</artifactId>
<version>${mapstruct-spring-extensions.version}</version>
</dependency>
<dependency>
<groupId>org.mapstruct</groupId>
<artifactId>mapstruct-processor</artifactId>
<version>${mapstruct.version}</version>
</dependency>
<dependency>
<groupId>org.mapstruct.extensions.spring</groupId>
<artifactId>mapstruct-spring-annotations</artifactId>
<version>${mapstruct-spring-annotations.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok-mapstruct-binding</artifactId>
<version>${lombok-mapstruct-binding.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-autoconfigure</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-all</artifactId>
</dependency>
<dependency>
<groupId>net.logstash.logback</groupId>
<artifactId>logstash-logback-encoder</artifactId>
</dependency>
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-api</artifactId>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-core</artifactId>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.datatype</groupId>
<artifactId>jackson-datatype-jsr310</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-validation</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
</dependency>
<dependency>
<groupId>commons-beanutils</groupId>
<artifactId>commons-beanutils</artifactId>
</dependency>
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
</dependency>
<!-- https://mvnrepository.com/artifact/org.springdoc/springdoc-openapi-common -->
<dependency>
<groupId>org.springdoc</groupId>
<artifactId>springdoc-openapi-common</artifactId>
</dependency>
</dependencies>
</project>
Related logs
"C:\Program Files\Java\jdk-20\bin\java.exe" -Dvisualvm.id=8147785106100 -Dmaven.multiModuleProjectDirectory=D:\workspace\cloud-workspace\cloud-common -Djansi.passthrough=true -Xms512m -Xmx1024m -Dfile.encoding=UTF-8 -Dmaven.home=D:\Server\apache-maven-3.9.2 -Dclassworlds.conf=D:\Server\apache-maven-3.9.2\bin\m2.conf "-Dmaven.ext.class.path=D:\Software\IntelliJ IDEA 2023.1.2\plugins\maven\lib\maven-event-listener.jar" "-javaagent:D:\Software\IntelliJ IDEA 2023.1.2\lib\idea_rt.jar=58531:D:\Software\IntelliJ IDEA 2023.1.2\bin" -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath D:\Server\apache-maven-3.9.2\boot\plexus-classworlds-2.7.0.jar;D:\Server\apache-maven-3.9.2\boot\plexus-classworlds.license org.codehaus.classworlds.Launcher -Didea.version=2023.1.2 --update-snapshots -s D:\Server\apache-maven-3.9.2\conf\settings.xml clean package install
[INFO] Scanning for projects...
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Build Order:
[INFO]
[INFO] cloud-common [pom]
[INFO] cloud-common-client [jar]
[INFO] cloud-common-server [jar]
[INFO]
[INFO] -------------------< com.qolome.cloud:cloud-common >--------------------
[INFO] Building cloud-common 2.1.3-jre20 [1/3]
[INFO] from pom.xml
[INFO] --------------------------------[ pom ]---------------------------------
[INFO]
[INFO] --- clean:3.2.0:clean (default-clean) @ cloud-common ---
[INFO]
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common >>>
[INFO]
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common <<<
[INFO]
[INFO]
[INFO] --- source:3.2.1:jar (default) @ cloud-common ---
[INFO]
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common ---
[INFO] Not executing Javadoc as the project is not a Java classpath-capable package
[INFO]
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common >>>
[INFO]
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common <<<
[INFO]
[INFO]
[INFO] --- source:3.2.1:jar (default) @ cloud-common ---
[INFO]
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common ---
[INFO] Not executing Javadoc as the project is not a Java classpath-capable package
[INFO]
[INFO] --- install:3.1.1:install (default-install) @ cloud-common ---
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\pom.xml to D:\Server\Repository\com\qolome\cloud\cloud-common\2.1.3-jre20\cloud-common-2.1.3-jre20.pom
[INFO]
[INFO] ----------------< com.qolome.cloud:cloud-common-client >----------------
[INFO] Building cloud-common-client 2.1.3-jre20 [2/3]
[INFO] from cloud-common-client\pom.xml
[INFO] --------------------------------[ jar ]---------------------------------
[INFO]
[INFO] --- clean:3.2.0:clean (default-clean) @ cloud-common-client ---
[INFO] Deleting D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target
[INFO]
[INFO] --- resources:3.3.1:resources (default-resources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO]
[INFO] --- compiler:3.11.0:compile (default-compile) @ cloud-common-client ---
[INFO] Changes detected - recompiling the module! :source
[INFO] Compiling 25 source files with javac [debug release 20] to target\classes
[INFO]
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common-client >>>
[INFO]
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common-client <<<
[INFO]
[INFO]
[INFO] --- source:3.2.1:jar (default) @ cloud-common-client ---
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-sources.jar
[INFO]
[INFO] --- resources:3.3.1:testResources (default-testResources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\test\resources
[INFO]
[INFO] --- compiler:3.11.0:testCompile (default-testCompile) @ cloud-common-client ---
[INFO] No sources to compile
[INFO]
[INFO] --- surefire:3.0.0:test (default-test) @ cloud-common-client ---
[INFO] No tests to run.
[INFO]
[INFO] --- jar:3.3.0:jar (default-jar) @ cloud-common-client ---
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20.jar
[INFO]
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common-client ---
[INFO] No previous run data found, generating javadoc.
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-javadoc.jar
[INFO]
[INFO] --- resources:3.3.1:resources (default-resources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\main\resources
[INFO]
[INFO] --- compiler:3.11.0:compile (default-compile) @ cloud-common-client ---
[INFO] Nothing to compile - all classes are up to date
[INFO]
[INFO] >>> source:3.2.1:jar (default) > generate-sources @ cloud-common-client >>>
[INFO]
[INFO] <<< source:3.2.1:jar (default) < generate-sources @ cloud-common-client <<<
[INFO]
[INFO]
[INFO] --- source:3.2.1:jar (default) @ cloud-common-client ---
[WARNING] artifact com.qolome.cloud:cloud-common-client:java-source:sources:2.1.3-jre20 already attached, replace previous instance
[INFO]
[INFO] --- resources:3.3.1:testResources (default-testResources) @ cloud-common-client ---
[INFO] skip non existing resourceDirectory D:\workspace\cloud-workspace\cloud-common\cloud-common-client\src\test\resources
[INFO]
[INFO] --- compiler:3.11.0:testCompile (default-testCompile) @ cloud-common-client ---
[INFO] No sources to compile
[INFO]
[INFO] --- surefire:3.0.0:test (default-test) @ cloud-common-client ---
[INFO] No tests to run.
[INFO] Skipping execution of surefire because it has already been run for this configuration
[INFO]
[INFO] --- jar:3.3.0:jar (default-jar) @ cloud-common-client ---
[INFO]
[INFO] --- javadoc:3.5.0:jar (attach-javadocs) @ cloud-common-client ---
[INFO] Configuration changed, re-generating javadoc.
[INFO] Building jar: D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-javadoc.jar
[WARNING] artifact com.qolome.cloud:cloud-common-client:javadoc:javadoc:2.1.3-jre20 already attached, replace previous instance
[INFO]
[INFO] --- install:3.1.1:install (default-install) @ cloud-common-client ---
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\pom.xml to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20.pom
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20.jar to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20.jar
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-sources.jar to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20-sources.jar
[INFO] Installing D:\workspace\cloud-workspace\cloud-common\cloud-common-client\target\cloud-common-client-2.1.3-jre20-javadoc.jar to D:\Server\Repository\com\qolome\cloud\cloud-common-client\2.1.3-jre20\cloud-common-client-2.1.3-jre20-javadoc.jar
[INFO]
[INFO] ----------------< com.qolome.cloud:cloud-common-server >----------------
[INFO] Building cloud-common-server 2.1.3-jre20 [3/3]
[INFO] from cloud-common-server\pom.xml
[INFO] --------------------------------[ jar ]---------------------------------
[INFO]
[INFO] --- clean:3.2.0:clean (default-clean) @ cloud-common-server ---
[INFO] Deleting D:\workspace\cloud-workspace\cloud-common\cloud-common-server\target
[INFO]
[INFO] --- resources:3.3.1:resources (default-resources) @ cloud-common-server ---
[INFO] Copying 0 resource from src\main\resources to target\classes
[INFO] Copying 1 resource from src\main\resources to target\classes
[INFO]
[INFO] --- compiler:3.11.0:compile (default-compile) @ cloud-common-server ---
[INFO] Changes detected - recompiling the module! :dependency
[INFO] Compiling 9 source files with javac [debug release 20] to target\classes
[INFO] -------------------------------------------------------------
[ERROR] COMPILATION ERROR :
[INFO] -------------------------------------------------------------
[ERROR] 服务配置文件不正确, 或构造处理程序对象javax.annotation.processing.Processor: Provider org.mapstruct.extensions.spring.converter.ConverterMapperProcessor could not be instantiated时抛出异常错误
[INFO] 1 error
[INFO] -------------------------------------------------------------
[INFO] ------------------------------------------------------------------------
[INFO] Reactor Summary for cloud-common 2.1.3-jre20:
[INFO]
[INFO] cloud-common ....................................... SUCCESS [ 0.663 s]
[INFO] cloud-common-client ................................ SUCCESS [ 4.449 s]
[INFO] cloud-common-server ................................ FAILURE [ 0.586 s]
[INFO] ------------------------------------------------------------------------
[INFO] BUILD FAILURE
[INFO] ------------------------------------------------------------------------
[INFO] Total time: 5.914 s
[INFO] Finished at: 2023-06-17T16:27:29+08:00
[INFO] ------------------------------------------------------------------------
[WARNING]
[WARNING] Plugin validation issues were detected in 2 plugin(s)
[WARNING]
[WARNING] * org.apache.maven.plugins:maven-source-plugin:3.2.1
[WARNING] * org.apache.maven.plugins:maven-javadoc-plugin:3.5.0
[WARNING]
[WARNING] For more or less details, use 'maven.plugin.validation' property with one of the values (case insensitive): [BRIEF, DEFAULT, VERBOSE]
[WARNING]
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.11.0:compile (default-compile) on project cloud-common-server: Compilation failure
[ERROR] 服务配置文件不正确, 或构造处理程序对象javax.annotation.processing.Processor: Provider org.mapstruct.extensions.spring.converter.ConverterMapperProcessor could not be instantiated时抛出异常错误
[ERROR]
[ERROR] -> [Help 1]
[ERROR]
[ERROR] To see the full stack trace of the errors, re-run Maven with the -e switch.
[ERROR] Re-run Maven using the -X switch to enable full debug logging.
[ERROR]
[ERROR] For more information about the errors and possible solutions, please read the following articles:
[ERROR] [Help 1] http://cwiki.apache.org/confluence/display/MAVEN/MojoFailureException
[ERROR]
[ERROR] After correcting the problems, you can resume the build with the command
[ERROR] mvn <args> -rf :cloud-common-server
Process finished with exit code 1
Raimund Klein commented
Please compare https://mapstruct.org/documentation/stable/reference/html/#_apache_maven and https://mapstruct.org/documentation/spring-extensions/reference/html/#_apache_maven. Only the annotation packages should be in the dependencies
section.
iqolome commented
@Chessray Thanks, found the problem
<properties>
<java.version>20</java.version>
<maven.compiler.release>20</maven.compiler.release>
<maven.compiler.source>20</maven.compiler.source>
<maven.compiler.target>20</maven.compiler.target>
<maven.compiler.encoding>UTF-8</maven.compiler.encoding>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<!-- mapstruct IDE Support -->
<m2e.apt.activation>jdt_apt</m2e.apt.activation>
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok -->
<lombok.version>1.18.28</lombok.version>
<!-- https://mvnrepository.com/artifact/org.projectlombok/lombok-mapstruct-binding -->
<lombok-mapstruct-binding.version>0.2.0</lombok-mapstruct-binding.version>
<!-- https://mvnrepository.com/artifact/org.mapstruct/mapstruct -->
<mapstruct.version>1.5.5.Final</mapstruct.version>
<!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-annotations -->
<mapstruct-spring-annotations.version>1.0.1</mapstruct-spring-annotations.version>
<!-- https://mvnrepository.com/artifact/org.mapstruct.extensions.spring/mapstruct-spring-extensions -->
<mapstruct-spring-extensions.version>1.0.1</mapstruct-spring-extensions.version>
</properties>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<source>${maven.compiler.source}</source>
<target>${maven.compiler.source}</target>
<annotationProcessorPaths>
<path>
<groupId>org.mapstruct</groupId>
<artifactId>mapstruct-processor</artifactId>
<version>${mapstruct.version}</version>
</path>
<path>
<groupId>org.mapstruct.extensions.spring</groupId>
<artifactId>mapstruct-spring-extensions</artifactId>
<version>${mapstruct-spring-extensions.version}</version>
</path>
<path>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>${lombok.version}</version>
</path>
</annotationProcessorPaths>
</configuration>
</plugin>