深入JVM分析spring-boot应用hibernate-validator NoClassDefFoundError

问题

最近排查一个spring boot应用抛出hibernate.validator NoClassDefFoundError的问题,异常信息如下:

Caused by: java.lang.NoClassDefFoundError: Could not initialize class org.hibernate.validator.internal.engine.ConfigurationImpl
	at org.hibernate.validator.HibernateValidator.createGenericConfiguration(HibernateValidator.java:33) ~[hibernate-validator-5.3.5.Final.jar:5.3.5.Final]
	at javax.validation.Validation$GenericBootstrapImpl.configure(Validation.java:276) ~[validation-api-1.1.0.Final.jar:na]
	at org.springframework.boot.validation.MessageInterpolatorFactory.getObject(MessageInterpolatorFactory.java:53) ~[spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE]
	at org.springframework.boot.autoconfigure.validation.DefaultValidatorConfiguration.defaultValidator(DefaultValidatorConfiguration.java:43) ~[spring-boot-autoconfigure-1.5.3.RELEASE.jar:1.5.3.RELEASE]
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_112]
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_112]
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_112]
	at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_112]
	at org.springframework.beans.factory.support.SimpleInstantiationStrategy.instantiate(SimpleInstantiationStrategy.java:162) ~[spring-beans-4.3.8.RELEASE.jar:4.3.8.RELEASE]
	... 32 common frames omitted

这个错误信息表面上是NoClassDefFoundError,但是实际上ConfigurationImpl这个类是在hibernate-validator-5.3.5.Final.jar里的,不应该出现找不到类的情况。

那为什么应用里抛出这个NoClassDefFoundError

有经验的开发人员从Could not initialize class 这个信息就可以知道,实际上是一个类在初始化时抛出的异常,比如static的静态代码块,或者static字段初始化的异常。

谁初始化了 org.hibernate.validator.internal.engine.ConfigurationImpl

但是当我们在HibernateValidator 这个类,创建ConfigurationImpl的代码块里打断点时,发现有两个线程触发了断点:

public class HibernateValidator implements ValidationProvider<HibernateValidatorConfiguration> {
	@Override
	public Configuration<?> createGenericConfiguration(BootstrapState state) {
		return new ConfigurationImpl( state );
	}

其中一个线程的调用栈是:

Thread [background-preinit] (Class load: ConfigurationImpl)
	HibernateValidator.createGenericConfiguration(BootstrapState) line: 33
	Validation$GenericBootstrapImpl.configure() line: 276
	BackgroundPreinitializer$ValidationInitializer.run() line: 107
	BackgroundPreinitializer$1.runSafely(Runnable) line: 59
	BackgroundPreinitializer$1.run() line: 52
	Thread.run() line: 745

另外一个线程调用栈是:

Thread [main] (Suspended (breakpoint at line 33 in HibernateValidator))
	owns: ConcurrentHashMap<K,V>  (id=52)
	owns: Object  (id=53)
	HibernateValidator.createGenericConfiguration(BootstrapState) line: 33
	Validation$GenericBootstrapImpl.configure() line: 276
	MessageInterpolatorFactory.getObject() line: 53
	DefaultValidatorConfiguration.defaultValidator() line: 43
	NativeMethodAccessorImpl.invoke0(Method, Object, Object[]) line: not available [native method]
	NativeMethodAccessorImpl.invoke(Object, Object[]) line: 62
	DelegatingMethodAccessorImpl.invoke(Object, Object[]) line: 43
	Method.invoke(Object, Object...) line: 498
	CglibSubclassingInstantiationStrategy(SimpleInstantiationStrategy).instantiate(RootBeanDefinition, String, BeanFactory, Object, Method, Object...) line: 162
	ConstructorResolver.instantiateUsingFactoryMethod(String, RootBeanDefinition, Object[]) line: 588
	DefaultListableBeanFactory(AbstractAutowireCapableBeanFactory).instantiateUsingFactoryMethod(String, RootBeanDefinition, Object[]) line: 1173

显然,这个线程的调用栈是常见的spring的初始化过程。

BackgroundPreinitializer 做了什么

那么重点来看下 BackgroundPreinitializer 线程做了哪些事情:

@Order(LoggingApplicationListener.DEFAULT_ORDER + 1)
public class BackgroundPreinitializer
		implements ApplicationListener<ApplicationEnvironmentPreparedEvent> {

	@Override
	public void onApplicationEvent(ApplicationEnvironmentPreparedEvent event) {
		try {
			Thread thread = new Thread(new Runnable() {

				@Override
				public void run() {
					runSafely(new MessageConverterInitializer());
					runSafely(new MBeanFactoryInitializer());
					runSafely(new ValidationInitializer());
					runSafely(new JacksonInitializer());
					runSafely(new ConversionServiceInitializer());
				}

				public void runSafely(Runnable runnable) {
					try {
						runnable.run();
					}
					catch (Throwable ex) {
						// Ignore
					}
				}

			}, "background-preinit");
			thread.start();
		}

可以看到BackgroundPreinitializer类是spring boot为了加速应用的初始化,以一个独立的线程来加载hibernate validator这些组件。

这个 background-preinit 线程会吞掉所有的异常。

显然ConfigurationImpl 初始化的异常也被吞掉了,那么如何才能获取到最原始的信息?

获取到最原始的异常信息

BackgroundPreinitializerrun() 函数里打一个断点(注意是Suspend thread类型, 不是Suspend VM),让它先不要触发ConfigurationImpl的加载,让spring boot的正常流程去触发ConfigurationImpl的加载,就可以知道具体的信息了。

那么打出来的异常信息是:

Caused by: java.lang.NoSuchMethodError: org.jboss.logging.Logger.getMessageLogger(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Object;
	at org.hibernate.validator.internal.util.logging.LoggerFactory.make(LoggerFactory.java:19) ~[hibernate-validator-5.3.5.Final.jar:5.3.5.Final]
	at org.hibernate.validator.internal.util.Version.<clinit>(Version.java:22) ~[hibernate-validator-5.3.5.Final.jar:5.3.5.Final]
	at org.hibernate.validator.internal.engine.ConfigurationImpl.<clinit>(ConfigurationImpl.java:71) ~[hibernate-validator-5.3.5.Final.jar:5.3.5.Final]
	at org.hibernate.validator.HibernateValidator.createGenericConfiguration(HibernateValidator.java:33) ~[hibernate-validator-5.3.5.Final.jar:5.3.5.Final]
	at javax.validation.Validation$GenericBootstrapImpl.configure(Validation.java:276) ~[validation-api-1.1.0.Final.jar:na]
	at org.springframework.boot.validation.MessageInterpolatorFactory.getObject(MessageInterpolatorFactory.java:53) ~[spring-boot-1.5.3.RELEASE.jar:1.5.3.RELEASE]

那么可以看出是 org.jboss.logging.Logger 这个类不兼容,少了getMessageLogger(Ljava/lang/Class;Ljava/lang/String;)Ljava/lang/Object 这个函数。

那么检查下应用的依赖,可以发现org.jboss.logging.Loggerjboss-common-1.2.1.GA.jarjboss-logging-3.3.1.Final.jar里都有。

显然是jboss-common-1.2.1.GA.jar 这个依赖过时了,需要排除掉。

总结异常的发生流程

  1. 应用依赖了jboss-common-1.2.1.GA.jar,它里面的org.jboss.logging.Logger太老

  2. spring boot启动时,BackgroundPreinitializer里的线程去尝试加载ConfigurationImpl,然后触发了org.jboss.logging.Logger的函数执行问题

  3. BackgroundPreinitializer 吃掉了异常信息,jvm把ConfigurationImpl标记为不可用的

  4. spring boot正常的流程去加载ConfigurationImpl,jvm发现ConfigurationImpl类是不可用,直接抛出NoClassDefFoundError

    Caused by: java.lang.NoClassDefFoundError: Could not initialize class org.hibernate.validator.internal.engine.ConfigurationImpl
    

深入JVM

为什么第二次尝试加载ConfigurationImpl时,会直接抛出java.lang.NoClassDefFoundError: Could not initialize class

下面用一段简单的代码来重现这个问题:

try {
  org.hibernate.validator.internal.util.Version.touch();
} catch (Throwable e) {
  e.printStackTrace();
}
System.in.read();

try {
  org.hibernate.validator.internal.util.Version.touch();
} catch (Throwable e) {
  e.printStackTrace();
}

使用HSDB来确定类的状态

当抛出第一个异常时,尝试用HSDB来看下这个类的状态。

sudo java -classpath "$JAVA_HOME/lib/sa-jdi.jar" sun.jvm.hotspot.HSDB

然后在HSDB console里查找到Version的地址信息

hsdb> class org.hibernate.validator.internal.util.Version
org/hibernate/validator/internal/util/Version @0x00000007c0060218

然后在Inspector查找到这个地址,发现_init_state是5。

hsfdb-version-class.png

再看下hotspot代码,可以发现5对应的定义是initialization_error

// /hotspot/src/share/vm/oops/instanceKlass.hpp
// See "The Java Virtual Machine Specification" section 2.16.2-5 for a detailed description
// of the class loading & initialization procedure, and the use of the states.
enum ClassState {
  allocated,                          // allocated (but not yet linked)
  loaded,                             // loaded and inserted in class hierarchy (but not linked yet)
  linked,                             // successfully linked/verified (but not initialized yet)
  being_initialized,                  // currently running class initializer
  fully_initialized,                  // initialized (successfull final state)
  initialization_error                // error happened during initialization
};

JVM规范里关于Initialization的内容

http://docs.oracle.com/javase/specs/jvms/se7/html/jvms-5.html#jvms-5.5

从规范里可以看到初始一个类/接口有12步,比较重要的两步都用黑体标记出来了:

    1. If the Class object for C is in an erroneous state, then initialization is not possible. Release LC and throw a NoClassDefFoundError.
    1. Otherwise, the class or interface initialization method must have completed abruptly by throwing some exception E. If the class of E is not Error or one of its subclasses, then create a new instance of the class ExceptionInInitializerError with E as the argument, and use this object in place of E in the following step.

第一次尝试加载Version类时

当第一次尝试加载时,hotspot InterpreterRuntime在解析invokestatic指令时,尝试加载org.hibernate.validator.internal.util.Version类,InstanceKlass_init_state先是标记为being_initialized,然后当加载失败时,被标记为initialization_error

对应Initialization的11步。

// hotspot/src/share/vm/oops/instanceKlass.cpp
// Step 10 and 11
Handle e(THREAD, PENDING_EXCEPTION);
CLEAR_PENDING_EXCEPTION;
// JVMTI has already reported the pending exception
// JVMTI internal flag reset is needed in order to report ExceptionInInitializerError
JvmtiExport::clear_detected_exception((JavaThread*)THREAD);
{
  EXCEPTION_MARK;
  this_oop->set_initialization_state_and_notify(initialization_error, THREAD);
  CLEAR_PENDING_EXCEPTION;   // ignore any exception thrown, class initialization error is thrown below
  // JVMTI has already reported the pending exception
  // JVMTI internal flag reset is needed in order to report ExceptionInInitializerError
  JvmtiExport::clear_detected_exception((JavaThread*)THREAD);
}
DTRACE_CLASSINIT_PROBE_WAIT(error, InstanceKlass::cast(this_oop()), -1,wait);
if (e->is_a(SystemDictionary::Error_klass())) {
  THROW_OOP(e());
} else {
  JavaCallArguments args(e);
  THROW_ARG(vmSymbols::java_lang_ExceptionInInitializerError(),
            vmSymbols::throwable_void_signature(),
            &args);
}

第二次尝试加载Version类时

当第二次尝试加载时,检查InstanceKlass_init_stateinitialization_error,则直接抛出NoClassDefFoundError: Could not initialize class.

对应Initialization的5步。

// hotspot/src/share/vm/oops/instanceKlass.cpp
void InstanceKlass::initialize_impl(instanceKlassHandle this_oop, TRAPS) {
// ...
    // Step 5
    if (this_oop->is_in_error_state()) {
      DTRACE_CLASSINIT_PROBE_WAIT(erroneous, InstanceKlass::cast(this_oop()), -1,wait);
      ResourceMark rm(THREAD);
      const char* desc = "Could not initialize class ";
      const char* className = this_oop->external_name();
      size_t msglen = strlen(desc) + strlen(className) + 1;
      char* message = NEW_RESOURCE_ARRAY(char, msglen);
      if (NULL == message) {
        // Out of memory: can't create detailed error message
        THROW_MSG(vmSymbols::java_lang_NoClassDefFoundError(), className);
      } else {
        jio_snprintf(message, msglen, "%s%s", desc, className);
        THROW_MSG(vmSymbols::java_lang_NoClassDefFoundError(), message);
      }
    }

总结

  • spring boot在BackgroundPreinitializer类里用一个独立的线程来加载validator,并吃掉了原始异常
  • 第一次加载失败的类,在jvm里会被标记为initialization_error,再次加载时会直接抛出NoClassDefFoundError: Could not initialize class
  • 当在代码里吞掉异常时要谨慎,否则排查问题带来很大的困难
  • http://docs.oracle.com/javase/specs/jvms/se7/html/jvms-5.html#jvms-5.5

公众号

欢迎关注公众号:横云断岭的专栏,专注分享Java,Spring Boot,Arthas,Dubbo。

横云断岭的专栏

D:\software\jdk17\bin\java.exe -agentlib:jdwp=transport=dt_socket,address=127.0.0.1:8853,suspend=y,server=n -XX:TieredStopAtLevel=1 -Dspring.output.ansi.enabled=always -Dcom.sun.management.jmxremote -Dspring.jmx.enabled=true -Dspring.liveBeansView.mbeanDomain -Dspring.application.admin.enabled=true "-Dmanagement.endpoints.jmx.exposure.include=*" -javaagent:C:\Users\demo\AppData\Local\JetBrains\IntelliJIdea2023.3\captureAgent\debugger-agent.jar=file:/C:/Users/demo/AppData/Local/Temp/capture6.props -Dfile.encoding=UTF-8 -classpath "D:\code\project\quin-faith-tag\faithtag-app\target\classes;D:\code\project\quin-faith-tag\faithtag-infrastructure\target\classes;D:\code\project\quin-faith-tag\faithtag-common\faithtag-common-core\target\classes;D:\software\apache-maven-3.9.6\maven-repository\cn\hutool\hutool-all\5.8.33\hutool-all-5.8.33.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-data-redis\3.3.5\spring-boot-starter-data-redis-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\io\lettuce\lettuce-core\6.3.2.RELEASE\lettuce-core-6.3.2.RELEASE.jar;D:\software\apache-maven-3.9.6\maven-repository\io\netty\netty-common\4.1.114.Final\netty-common-4.1.114.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\netty\netty-handler\4.1.114.Final\netty-handler-4.1.114.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\netty\netty-resolver\4.1.114.Final\netty-resolver-4.1.114.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\netty\netty-buffer\4.1.114.Final\netty-buffer-4.1.114.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\netty\netty-transport-native-unix-common\4.1.114.Final\netty-transport-native-unix-common-4.1.114.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\netty\netty-codec\4.1.114.Final\netty-codec-4.1.114.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\netty\netty-transport\4.1.114.Final\netty-transport-4.1.114.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\projectreactor\reactor-core\3.6.11\reactor-core-3.6.11.jar;D:\software\apache-maven-3.9.6\maven-repository\org\reactivestreams\reactive-streams\1.0.4\reactive-streams-1.0.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\data\spring-data-redis\3.3.5\spring-data-redis-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\data\spring-data-keyvalue\3.3.5\spring-data-keyvalue-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\data\spring-data-commons\3.3.5\spring-data-commons-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-oxm\6.1.14\spring-oxm-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-context-support\6.1.14\spring-context-support-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\jakarta\servlet\jakarta.servlet-api\6.0.0\jakarta.servlet-api-6.0.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-validation\3.3.5\spring-boot-starter-validation-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\hibernate\validator\hibernate-validator\8.0.1.Final\hibernate-validator-8.0.1.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\classmate\1.7.0\classmate-1.7.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-json\3.3.5\spring-boot-starter-json-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\datatype\jackson-datatype-jdk8\2.17.2\jackson-datatype-jdk8-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\module\jackson-module-parameter-names\2.17.2\jackson-module-parameter-names-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\cloud\spring-cloud-commons\4.1.4\spring-cloud-commons-4.1.4.jar;D:\code\project\quin-faith-tag\faithtag-common\faithtag-common-feign\target\classes;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\cloud\spring-cloud-starter-alibaba-sentinel\2023.0.1.3\spring-cloud-starter-alibaba-sentinel-2023.0.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-transport-simple-http\1.8.8\sentinel-transport-simple-http-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-transport-common\1.8.8\sentinel-transport-common-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-datasource-extension\1.8.8\sentinel-datasource-extension-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\fastjson\1.2.83_noneautotype\fastjson-1.2.83_noneautotype.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-annotation-aspectj\1.8.8\sentinel-annotation-aspectj-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-core\1.8.8\sentinel-core-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\org\aspectj\aspectjweaver\1.9.22.1\aspectjweaver-1.9.22.1.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\cloud\spring-cloud-circuitbreaker-sentinel\2023.0.1.3\spring-cloud-circuitbreaker-sentinel-2023.0.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-reactor-adapter\1.8.8\sentinel-reactor-adapter-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-spring-webflux-adapter\1.8.8\sentinel-spring-webflux-adapter-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-spring-webmvc-v6x-adapter\1.8.8\sentinel-spring-webmvc-v6x-adapter-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-web-adapter-common\1.8.8\sentinel-web-adapter-common-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-parameter-flow-control\1.8.8\sentinel-parameter-flow-control-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\googlecode\concurrentlinkedhashmap\concurrentlinkedhashmap-lru\1.4.2\concurrentlinkedhashmap-lru-1.4.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-cluster-server-default\1.8.8\sentinel-cluster-server-default-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-cluster-common-default\1.8.8\sentinel-cluster-common-default-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\csp\sentinel-cluster-client-default\1.8.8\sentinel-cluster-client-default-1.8.8.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\cloud\spring-cloud-alibaba-sentinel-datasource\2023.0.1.3\spring-cloud-alibaba-sentinel-datasource-2023.0.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\cloud\spring-cloud-alibaba-commons\2023.0.1.3\spring-cloud-alibaba-commons-2023.0.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\cloud\spring-cloud-starter-openfeign\4.1.3\spring-cloud-starter-openfeign-4.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\cloud\spring-cloud-starter\4.1.4\spring-cloud-starter-4.1.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\cloud\spring-cloud-context\4.1.4\spring-cloud-context-4.1.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\security\spring-security-rsa\1.1.3\spring-security-rsa-1.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\org\bouncycastle\bcprov-jdk18on\1.78\bcprov-jdk18on-1.78.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\cloud\spring-cloud-openfeign-core\4.1.3\spring-cloud-openfeign-core-4.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\io\github\openfeign\form\feign-form-spring\3.8.0\feign-form-spring-3.8.0.jar;D:\software\apache-maven-3.9.6\maven-repository\io\github\openfeign\form\feign-form\3.8.0\feign-form-3.8.0.jar;D:\software\apache-maven-3.9.6\maven-repository\commons-fileupload\commons-fileupload\1.5\commons-fileupload-1.5.jar;D:\software\apache-maven-3.9.6\maven-repository\io\github\openfeign\feign-core\13.3\feign-core-13.3.jar;D:\software\apache-maven-3.9.6\maven-repository\io\github\openfeign\feign-slf4j\13.3\feign-slf4j-13.3.jar;D:\software\apache-maven-3.9.6\maven-repository\io\github\openfeign\feign-okhttp\13.3\feign-okhttp-13.3.jar;D:\software\apache-maven-3.9.6\maven-repository\com\squareup\okhttp3\okhttp\4.12.0\okhttp-4.12.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\squareup\okio\okio\3.6.0\okio-3.6.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\squareup\okio\okio-jvm\3.6.0\okio-jvm-3.6.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jetbrains\kotlin\kotlin-stdlib-common\1.9.25\kotlin-stdlib-common-1.9.25.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jetbrains\kotlin\kotlin-stdlib-jdk8\1.9.25\kotlin-stdlib-jdk8-1.9.25.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jetbrains\kotlin\kotlin-stdlib\1.9.25\kotlin-stdlib-1.9.25.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jetbrains\annotations\13.0\annotations-13.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jetbrains\kotlin\kotlin-stdlib-jdk7\1.9.25\kotlin-stdlib-jdk7-1.9.25.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\cloud\spring-cloud-starter-loadbalancer\4.1.4\spring-cloud-starter-loadbalancer-4.1.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\cloud\spring-cloud-loadbalancer\4.1.4\spring-cloud-loadbalancer-4.1.4.jar;D:\software\apache-maven-3.9.6\maven-repository\io\projectreactor\addons\reactor-extra\3.5.2\reactor-extra-3.5.2.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-cache\3.3.5\spring-boot-starter-cache-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\stoyanr\evictor\1.0.0\evictor-1.0.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\github\ben-manes\caffeine\caffeine\3.1.8\caffeine-3.1.8.jar;D:\software\apache-maven-3.9.6\maven-repository\org\checkerframework\checker-qual\3.37.0\checker-qual-3.37.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\google\errorprone\error_prone_annotations\2.21.1\error_prone_annotations-2.21.1.jar;D:\code\project\quin-faith-tag\faithtag-common\faithtag-common-mybatis\target\classes;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-spring\3.5.9\mybatis-plus-spring-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-extension\3.5.9\mybatis-plus-extension-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-jsqlparser\3.5.9\mybatis-plus-jsqlparser-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\com\github\jsqlparser\jsqlparser\5.0\jsqlparser-5.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-jsqlparser-common\3.5.9\mybatis-plus-jsqlparser-common-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\io\swagger\core\v3\swagger-annotations-jakarta\2.2.25\swagger-annotations-jakarta-2.2.25.jar;D:\code\project\quin-faith-tag\faithtag-common\faithtag-common-excel\target\classes;D:\software\apache-maven-3.9.6\maven-repository\com\pig4cloud\excel\excel-spring-boot-starter\3.3.1\excel-spring-boot-starter-3.3.1.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-aop\3.3.5\spring-boot-starter-aop-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\easyexcel\4.0.2\easyexcel-4.0.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\easyexcel-core\4.0.2\easyexcel-core-4.0.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\alibaba\easyexcel-support\3.3.4\easyexcel-support-3.3.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\poi\poi\5.2.5\poi-5.2.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\commons\commons-collections4\4.4\commons-collections4-4.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\commons\commons-math3\3.6.1\commons-math3-3.6.1.jar;D:\software\apache-maven-3.9.6\maven-repository\com\zaxxer\SparseBitSet\1.3\SparseBitSet-1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\poi\poi-ooxml\5.2.5\poi-ooxml-5.2.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\poi\poi-ooxml-lite\5.2.5\poi-ooxml-lite-5.2.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\xmlbeans\xmlbeans\5.2.0\xmlbeans-5.2.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\github\virtuald\curvesapi\1.08\curvesapi-1.08.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\commons\commons-csv\1.11.0\commons-csv-1.11.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\ehcache\ehcache\3.10.8\ehcache-3.10.8.jar;D:\software\apache-maven-3.9.6\maven-repository\javax\cache\cache-api\1.1.1\cache-api-1.1.1.jar;D:\software\apache-maven-3.9.6\maven-repository\org\glassfish\jaxb\jaxb-runtime\4.0.5\jaxb-runtime-4.0.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\glassfish\jaxb\jaxb-core\4.0.5\jaxb-core-4.0.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\glassfish\jaxb\txw2\4.0.5\txw2-4.0.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\sun\istack\istack-commons-runtime\4.1.2\istack-commons-runtime-4.1.2.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\commons\commons-compress\1.27.1\commons-compress-1.27.1.jar;D:\software\apache-maven-3.9.6\maven-repository\commons-io\commons-io\2.17.0\commons-io-2.17.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-spring-boot3-starter\3.5.9\mybatis-plus-spring-boot3-starter-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus\3.5.9\mybatis-plus-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-core\3.5.9\mybatis-plus-core-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-annotation\3.5.9\mybatis-plus-annotation-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\org\mybatis\mybatis\3.5.16\mybatis-3.5.16.jar;D:\software\apache-maven-3.9.6\maven-repository\org\mybatis\mybatis-spring\3.0.4\mybatis-spring-3.0.4.jar;D:\software\apache-maven-3.9.6\maven-repository\com\baomidou\mybatis-plus-spring-boot-autoconfigure\3.5.9\mybatis-plus-spring-boot-autoconfigure-3.5.9.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-autoconfigure\3.3.5\spring-boot-autoconfigure-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot\3.3.5\spring-boot-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-jdbc\3.3.5\spring-boot-starter-jdbc-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\zaxxer\HikariCP\5.1.0\HikariCP-5.1.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-jdbc\6.1.14\spring-jdbc-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-tx\6.1.14\spring-tx-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\com\mysql\mysql-connector-j\9.0.0\mysql-connector-j-9.0.0.jar;D:\software\apache-maven-3.9.6\maven-repository\com\google\protobuf\protobuf-java\4.26.1\protobuf-java-4.26.1.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-undertow\3.3.5\spring-boot-starter-undertow-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\io\undertow\undertow-core\2.3.17.Final\undertow-core-2.3.17.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jboss\logging\jboss-logging\3.5.3.Final\jboss-logging-3.5.3.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jboss\xnio\xnio-api\3.8.16.Final\xnio-api-3.8.16.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\org\wildfly\common\wildfly-common\1.5.4.Final\wildfly-common-1.5.4.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\org\wildfly\client\wildfly-client-config\1.0.1.Final\wildfly-client-config-1.0.1.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jboss\xnio\xnio-nio\3.8.16.Final\xnio-nio-3.8.16.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jboss\threads\jboss-threads\3.5.0.Final\jboss-threads-3.5.0.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\io\undertow\undertow-servlet\2.3.17.Final\undertow-servlet-2.3.17.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\jakarta\annotation\jakarta.annotation-api\2.1.1\jakarta.annotation-api-2.1.1.jar;D:\software\apache-maven-3.9.6\maven-repository\io\undertow\undertow-websockets-jsr\2.3.17.Final\undertow-websockets-jsr-2.3.17.Final.jar;D:\software\apache-maven-3.9.6\maven-repository\jakarta\websocket\jakarta.websocket-api\2.1.1\jakarta.websocket-api-2.1.1.jar;D:\software\apache-maven-3.9.6\maven-repository\jakarta\websocket\jakarta.websocket-client-api\2.1.1\jakarta.websocket-client-api-2.1.1.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\tomcat\embed\tomcat-embed-el\10.1.31\tomcat-embed-el-10.1.31.jar;D:\code\project\quin-faith-tag\faithtag-common\faithtag-common-log\target\classes;D:\software\apache-maven-3.9.6\maven-repository\cn\hutool\hutool-extra\5.8.33\hutool-extra-5.8.33.jar;D:\software\apache-maven-3.9.6\maven-repository\cn\hutool\hutool-setting\5.8.33\hutool-setting-5.8.33.jar;D:\software\apache-maven-3.9.6\maven-repository\cn\hutool\hutool-log\5.8.33\hutool-log-5.8.33.jar;D:\software\apache-maven-3.9.6\maven-repository\cn\hutool\hutool-http\5.8.33\hutool-http-5.8.33.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\security\spring-security-core\6.3.4\spring-security-core-6.3.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\security\spring-security-crypto\6.3.4\spring-security-crypto-6.3.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-aop\6.1.14\spring-aop-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-beans\6.1.14\spring-beans-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-context\6.1.14\spring-context-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-expression\6.1.14\spring-expression-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\security\spring-security-oauth2-core\6.3.4\spring-security-oauth2-core-6.3.4.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-web\6.1.14\spring-web-6.1.14.jar;D:\code\project\quin-faith-tag\faithtag-common\faithtag-common-swagger\target\classes;D:\software\apache-maven-3.9.6\maven-repository\org\springdoc\springdoc-openapi-starter-webmvc-ui\2.6.0\springdoc-openapi-starter-webmvc-ui-2.6.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\webjars\swagger-ui\5.17.14\swagger-ui-5.17.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springdoc\springdoc-openapi-starter-webmvc-api\2.6.0\springdoc-openapi-starter-webmvc-api-2.6.0.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springdoc\springdoc-openapi-starter-common\2.6.0\springdoc-openapi-starter-common-2.6.0.jar;D:\software\apache-maven-3.9.6\maven-repository\io\swagger\core\v3\swagger-core-jakarta\2.2.22\swagger-core-jakarta-2.2.22.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\commons\commons-lang3\3.14.0\commons-lang3-3.14.0.jar;D:\software\apache-maven-3.9.6\maven-repository\io\swagger\core\v3\swagger-models-jakarta\2.2.22\swagger-models-jakarta-2.2.22.jar;D:\software\apache-maven-3.9.6\maven-repository\jakarta\validation\jakarta.validation-api\3.0.2\jakarta.validation-api-3.0.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\core\jackson-annotations\2.17.2\jackson-annotations-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\dataformat\jackson-dataformat-yaml\2.17.2\jackson-dataformat-yaml-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-webmvc\6.1.14\spring-webmvc-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\io\springboot\knife4j-boot-openapi3-ui\3.0.5\knife4j-boot-openapi3-ui-3.0.5.jar;D:\code\project\quin-faith-tag\faithtag-common\target\classes;D:\software\apache-maven-3.9.6\maven-repository\com\amazonaws\aws-java-sdk-s3\1.12.675\aws-java-sdk-s3-1.12.675.jar;D:\software\apache-maven-3.9.6\maven-repository\com\amazonaws\aws-java-sdk-kms\1.12.675\aws-java-sdk-kms-1.12.675.jar;D:\software\apache-maven-3.9.6\maven-repository\com\amazonaws\aws-java-sdk-core\1.12.675\aws-java-sdk-core-1.12.675.jar;D:\software\apache-maven-3.9.6\maven-repository\commons-logging\commons-logging\1.1.3\commons-logging-1.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\commons-codec\commons-codec\1.16.1\commons-codec-1.16.1.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\httpcomponents\httpclient\4.5.13\httpclient-4.5.13.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\httpcomponents\httpcore\4.4.16\httpcore-4.4.16.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\dataformat\jackson-dataformat-cbor\2.17.2\jackson-dataformat-cbor-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\joda-time\joda-time\2.8.1\joda-time-2.8.1.jar;D:\software\apache-maven-3.9.6\maven-repository\com\amazonaws\jmespath-java\1.12.675\jmespath-java-1.12.675.jar;D:\software\apache-maven-3.9.6\maven-repository\cn\hutool\hutool-core\5.8.33\hutool-core-5.8.33.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-configuration-processor\3.3.5\spring-boot-configuration-processor-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\github\ulisesbocchio\jasypt-spring-boot-starter\3.0.5\jasypt-spring-boot-starter-3.0.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\github\ulisesbocchio\jasypt-spring-boot\3.0.5\jasypt-spring-boot-3.0.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\jasypt\jasypt\1.9.3\jasypt-1.9.3.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-actuator\3.3.5\spring-boot-starter-actuator-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter\3.3.5\spring-boot-starter-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-starter-logging\3.3.5\spring-boot-starter-logging-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\ch\qos\logback\logback-classic\1.5.11\logback-classic-1.5.11.jar;D:\software\apache-maven-3.9.6\maven-repository\ch\qos\logback\logback-core\1.5.11\logback-core-1.5.11.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\logging\log4j\log4j-to-slf4j\2.23.1\log4j-to-slf4j-2.23.1.jar;D:\software\apache-maven-3.9.6\maven-repository\org\apache\logging\log4j\log4j-api\2.23.1\log4j-api-2.23.1.jar;D:\software\apache-maven-3.9.6\maven-repository\org\slf4j\jul-to-slf4j\2.0.16\jul-to-slf4j-2.0.16.jar;D:\software\apache-maven-3.9.6\maven-repository\org\yaml\snakeyaml\2.2\snakeyaml-2.2.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-actuator-autoconfigure\3.3.5\spring-boot-actuator-autoconfigure-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\boot\spring-boot-actuator\3.3.5\spring-boot-actuator-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\core\jackson-databind\2.17.2\jackson-databind-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\core\jackson-core\2.17.2\jackson-core-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\com\fasterxml\jackson\datatype\jackson-datatype-jsr310\2.17.2\jackson-datatype-jsr310-2.17.2.jar;D:\software\apache-maven-3.9.6\maven-repository\io\micrometer\micrometer-observation\1.13.6\micrometer-observation-1.13.6.jar;D:\software\apache-maven-3.9.6\maven-repository\io\micrometer\micrometer-commons\1.13.6\micrometer-commons-1.13.6.jar;D:\software\apache-maven-3.9.6\maven-repository\io\micrometer\micrometer-jakarta9\1.13.6\micrometer-jakarta9-1.13.6.jar;D:\software\apache-maven-3.9.6\maven-repository\io\micrometer\micrometer-core\1.13.6\micrometer-core-1.13.6.jar;D:\software\apache-maven-3.9.6\maven-repository\org\hdrhistogram\HdrHistogram\2.2.2\HdrHistogram-2.2.2.jar;D:\software\apache-maven-3.9.6\maven-repository\org\latencyutils\LatencyUtils\2.0.3\LatencyUtils-2.0.3.jar;D:\software\apache-maven-3.9.6\maven-repository\de\codecentric\spring-boot-admin-starter-client\3.3.5\spring-boot-admin-starter-client-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\de\codecentric\spring-boot-admin-client\3.3.5\spring-boot-admin-client-3.3.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\projectlombok\lombok\1.18.34\lombok-1.18.34.jar;D:\software\apache-maven-3.9.6\maven-repository\com\sun\xml\bind\jaxb-impl\4.0.5\jaxb-impl-4.0.5.jar;D:\software\apache-maven-3.9.6\maven-repository\com\sun\xml\bind\jaxb-core\4.0.5\jaxb-core-4.0.5.jar;D:\software\apache-maven-3.9.6\maven-repository\org\eclipse\angus\angus-activation\2.0.2\angus-activation-2.0.2.jar;D:\software\apache-maven-3.9.6\maven-repository\org\slf4j\slf4j-api\2.0.16\slf4j-api-2.0.16.jar;D:\software\apache-maven-3.9.6\maven-repository\jakarta\xml\bind\jakarta.xml.bind-api\4.0.2\jakarta.xml.bind-api-4.0.2.jar;D:\software\apache-maven-3.9.6\maven-repository\jakarta\activation\jakarta.activation-api\2.1.3\jakarta.activation-api-2.1.3.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-core\6.1.14\spring-core-6.1.14.jar;D:\software\apache-maven-3.9.6\maven-repository\org\springframework\spring-jcl\6.1.14\spring-jcl-6.1.14.jar;D:\software\idea2023.3.3\IntelliJ IDEA 2023.3.3\lib\idea_rt.jar" com.quin.faithtag.app.FaithtagAppApplication Connected to the target VM, address: '127.0.0.1:8853', transport: 'socket' Standard Commons Logging discovery in action with spring-jcl: please remove commons-logging.jar from classpath in order to avoid potential conflicts 15:07:51,018 |-WARN in ch.qos.logback.core.joran.action.ConversionRuleAction - [converterClass] attribute is deprecated and replaced by [class]. See element [conversionRule] near line 16 15:07:51,018 |-WARN in ch.qos.logback.core.joran.action.ConversionRuleAction - [converterClass] attribute is deprecated and replaced by [class]. See element [conversionRule] near line 18 15:07:51,018 |-WARN in ch.qos.logback.core.joran.action.ConversionRuleAction - [converterClass] attribute is deprecated and replaced by [class]. See element [conversionRule] near line 20 15:07:51,080 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%5p) %clr(34676){magenta} [traceId: %clr(%X{traceId}){magenta}] %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n%wEx" substituted for "${CONSOLE_LOG_PATTERN:-%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(${LOG_LEVEL_PATTERN:-%5p}) %clr(${PID:- }){magenta} [traceId: %clr(%X{traceId}){magenta}] %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n${LOG_EXCEPTION_CONVERSION_WORD:-%wEx}}" 15:07:51,080 |-INFO in ch.qos.logback.core.model.processor.ConversionRuleModelHandler - registering conversion word clr with class [org.springframework.boot.logging.logback.ColorConverter] 15:07:51,080 |-INFO in ch.qos.logback.core.model.processor.ConversionRuleModelHandler - registering conversion word wex with class [org.springframework.boot.logging.logback.WhitespaceThrowableProxyConverter] 15:07:51,080 |-INFO in ch.qos.logback.core.model.processor.ConversionRuleModelHandler - registering conversion word wEx with class [org.springframework.boot.logging.logback.ExtendedWhitespaceThrowableProxyConverter] 15:07:51,081 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - Processing appender named [console] 15:07:51,081 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - About to instantiate appender of type [ch.qos.logback.core.ConsoleAppender] 15:07:51,087 |-INFO in ch.qos.logback.core.model.processor.ImplicitModelHandler - Assuming default type [ch.qos.logback.classic.encoder.PatternLayoutEncoder] for [encoder] property 15:07:51,087 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%5p) %clr(34676){magenta} [traceId: %clr(%X{traceId}){magenta}] %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n%wEx" substituted for "${CONSOLE_LOG_PATTERN}" 15:07:51,122 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - Processing appender named [debug] 15:07:51,122 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - About to instantiate appender of type [ch.qos.logback.core.rolling.RollingFileAppender] 15:07:51,126 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "logs/faithtag-app/debug.log" substituted for "${log.path}/debug.log" 15:07:51,130 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "logs/faithtag-app/%d{yyyy-MM, aux}/debug.%d{yyyy-MM-dd}.%i.log.gz" substituted for "${log.path}/%d{yyyy-MM, aux}/debug.%d{yyyy-MM-dd}.%i.log.gz" 15:07:51,134 |-INFO in c.q.l.core.rolling.SizeAndTimeBasedRollingPolicy@317960117 - Archive files will be limited to [50 MB] each. 15:07:51,137 |-INFO in c.q.l.core.rolling.SizeAndTimeBasedRollingPolicy@317960117 - Will use gz compression 15:07:51,138 |-INFO in c.q.l.core.rolling.SizeAndTimeBasedRollingPolicy@317960117 - Will use the pattern logs/faithtag-app/%d{yyyy-MM, aux}/debug.%d{yyyy-MM-dd}.%i.log for the active file 15:07:51,152 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFileNamingAndTriggeringPolicy@4ced35ed - The date pattern is 'yyyy-MM-dd' from file name pattern 'logs/faithtag-app/%d{yyyy-MM, aux}/debug.%d{yyyy-MM-dd}.%i.log.gz'. 15:07:51,152 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFileNamingAndTriggeringPolicy@4ced35ed - Roll-over at midnight. 15:07:51,155 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFileNamingAndTriggeringPolicy@4ced35ed - Setting initial period to 2025-09-29T07:07:51.155Z 15:07:51,157 |-INFO in ch.qos.logback.core.model.processor.ImplicitModelHandler - Assuming default type [ch.qos.logback.classic.encoder.PatternLayoutEncoder] for [encoder] property 15:07:51,157 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%5p) %clr(34676){magenta} [traceId: %clr(%X{traceId}){magenta}] %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n%wEx" substituted for "${CONSOLE_LOG_PATTERN}" 15:07:51,159 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[debug] - Active log file name: logs/faithtag-app/debug.log 15:07:51,159 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[debug] - File property is set to [logs/faithtag-app/debug.log] 15:07:51,160 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - Processing appender named [error] 15:07:51,160 |-INFO in ch.qos.logback.core.model.processor.AppenderModelHandler - About to instantiate appender of type [ch.qos.logback.core.rolling.RollingFileAppender] 15:07:51,160 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "logs/faithtag-app/error.log" substituted for "${log.path}/error.log" 15:07:51,160 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "logs/faithtag-app/%d{yyyy-MM}/error.%d{yyyy-MM-dd}.%i.log.gz" substituted for "${log.path}/%d{yyyy-MM}/error.%d{yyyy-MM-dd}.%i.log.gz" 15:07:51,161 |-INFO in c.q.l.core.rolling.SizeAndTimeBasedRollingPolicy@740467528 - Archive files will be limited to [50 MB] each. 15:07:51,161 |-INFO in c.q.l.core.rolling.SizeAndTimeBasedRollingPolicy@740467528 - Will use gz compression 15:07:51,161 |-INFO in c.q.l.core.rolling.SizeAndTimeBasedRollingPolicy@740467528 - Will use the pattern logs/faithtag-app/%d{yyyy-MM}/error.%d{yyyy-MM-dd}.%i.log for the active file 15:07:51,161 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFileNamingAndTriggeringPolicy@7bd69e82 - The date pattern is 'yyyy-MM' from file name pattern 'logs/faithtag-app/%d{yyyy-MM}/error.%d{yyyy-MM-dd}.%i.log.gz'. 15:07:51,161 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFileNamingAndTriggeringPolicy@7bd69e82 - Rollover at start of every month. 15:07:51,161 |-INFO in ch.qos.logback.core.rolling.SizeAndTimeBasedFileNamingAndTriggeringPolicy@7bd69e82 - Setting initial period to 2025-09-29T07:07:51.161Z 15:07:51,161 |-INFO in ch.qos.logback.core.model.processor.ImplicitModelHandler - Assuming default type [ch.qos.logback.classic.encoder.PatternLayoutEncoder] for [encoder] property 15:07:51,161 |-INFO in ch.qos.logback.core.model.processor.ModelInterpretationContext@1e392345 - value "%clr(%d{yyyy-MM-dd HH:mm:ss.SSS}){faint} %clr(%5p) %clr(34676){magenta} [traceId: %clr(%X{traceId}){magenta}] %clr(---){faint} %clr([%15.15t]){faint} %clr(%-40.40logger{39}){cyan} %clr(:){faint} %m%n%wEx" substituted for "${CONSOLE_LOG_PATTERN}" 15:07:51,164 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[error] - Active log file name: logs/faithtag-app/error.log 15:07:51,164 |-INFO in ch.qos.logback.core.rolling.RollingFileAppender[error] - File property is set to [logs/faithtag-app/error.log] 15:07:51,164 |-INFO in ch.qos.logback.classic.model.processor.LoggerModelHandler - Setting level of logger [com.alibaba.nacos] to OFF 15:07:51,164 |-INFO in ch.qos.logback.classic.jul.LevelChangePropagator@74d7184a - Propagating OFF level on Logger[com.alibaba.nacos] onto the JUL framework 15:07:51,165 |-INFO in ch.qos.logback.core.model.processor.AppenderRefModelHandler - Attaching appender named [error] to Logger[com.alibaba.nacos] 15:07:51,165 |-INFO in ch.qos.logback.classic.model.processor.RootLoggerModelHandler - Setting level of ROOT logger to INFO 15:07:51,165 |-INFO in ch.qos.logback.classic.jul.LevelChangePropagator@74d7184a - Propagating INFO level on Logger[ROOT] onto the JUL framework 15:07:51,165 |-INFO in ch.qos.logback.core.model.processor.AppenderRefModelHandler - Attaching appender named [console] to Logger[ROOT] 15:07:51,165 |-INFO in ch.qos.logback.core.model.processor.AppenderRefModelHandler - Attaching appender named [debug] to Logger[ROOT] 15:07:51,165 |-INFO in ch.qos.logback.core.model.processor.AppenderRefModelHandler - Attaching appender named [error] to Logger[ROOT] 15:07:51,165 |-INFO in ch.qos.logback.core.model.processor.DefaultProcessor@51b01960 - End of configuration. 15:07:51,165 |-INFO in org.springframework.boot.logging.logback.SpringBootJoranConfigurator@6831d8fd - Registering current configuration as safe fallback point ::::::::: ::::::::::: :::::::: :+: :+: :+: :+: :+: +:+ +:+ +:+ +:+ +#++:++#+ +#+ :#: +#+ +#+ +#+ +#+# #+# #+# #+# #+# ### ########### ######## www.pig4cloud.com Pig Microservice Architecture 2025-09-29 15:07:51.204 INFO 34676 [traceId: ] --- [kground-preinit] o.h.validator.internal.util.Version : HV000001: Hibernate Validator 8.0.1.Final 2025-09-29 15:07:51.293 INFO 34676 [traceId: ] --- [ main] c.q.faithtag.app.FaithtagAppApplication : Starting FaithtagAppApplication using Java 17.0.8 with PID 34676 (D:\code\project\quin-faith-tag\faithtag-app\target\classes started by demo in D:\code\project\quin-faith-tag) 2025-09-29 15:07:51.294 INFO 34676 [traceId: ] --- [ main] c.q.faithtag.app.FaithtagAppApplication : The following 1 profile is active: "local" 2025-09-29 15:07:52.549 WARN 34676 [traceId: ] --- [ main] ConfigServletWebServerApplicationContext : Exception encountered during context initialization - cancelling refresh attempt: java.lang.IllegalStateException: Error processing condition on org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoConfiguration.propertySourcesPlaceholderConfigurer 2025-09-29 15:07:52.563 INFO 34676 [traceId: ] --- [ main] .s.b.a.l.ConditionEvaluationReportLogger : Error starting ApplicationContext. To display the condition evaluation report re-run your application with 'debug' enabled. 2025-09-29 15:07:52.592 ERROR 34676 [traceId: ] --- [ main] o.s.boot.SpringApplication : Application run failed java.lang.IllegalStateException: Error processing condition on org.springframework.boot.autoconfigure.context.PropertyPlaceholderAutoConfiguration.propertySourcesPlaceholderConfigurer at org.springframework.boot.autoconfigure.condition.SpringBootCondition.matches(SpringBootCondition.java:60) at org.springframework.context.annotation.ConditionEvaluator.shouldSkip(ConditionEvaluator.java:108) at org.springframework.context.annotation.ConfigurationClassBeanDefinitionReader.loadBeanDefinitionsForBeanMethod(ConfigurationClassBeanDefinitionReader.java:183) at org.springframework.context.annotation.ConfigurationClassBeanDefinitionReader.loadBeanDefinitionsForConfigurationClass(ConfigurationClassBeanDefinitionReader.java:144) at org.springframework.context.annotation.ConfigurationClassBeanDefinitionReader.loadBeanDefinitions(ConfigurationClassBeanDefinitionReader.java:120) at org.springframework.context.annotation.ConfigurationClassPostProcessor.processConfigBeanDefinitions(ConfigurationClassPostProcessor.java:429) at org.springframework.context.annotation.ConfigurationClassPostProcessor.postProcessBeanDefinitionRegistry(ConfigurationClassPostProcessor.java:290) at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanDefinitionRegistryPostProcessors(PostProcessorRegistrationDelegate.java:349) at org.springframework.context.support.PostProcessorRegistrationDelegate.invokeBeanFactoryPostProcessors(PostProcessorRegistrationDelegate.java:118) at org.springframework.context.support.AbstractApplicationContext.invokeBeanFactoryPostProcessors(AbstractApplicationContext.java:789) at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:607) at org.springframework.boot.web.servlet.context.ServletWebServerApplicationContext.refresh(ServletWebServerApplicationContext.java:146) at org.springframework.boot.SpringApplication.refresh(SpringApplication.java:754) at org.springframework.boot.SpringApplication.refreshContext(SpringApplication.java:456) at org.springframework.boot.SpringApplication.run(SpringApplication.java:335) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1363) at org.springframework.boot.SpringApplication.run(SpringApplication.java:1352) at com.quin.faithtag.app.FaithtagAppApplication.main(FaithtagAppApplication.java:16) Caused by: java.lang.IllegalStateException: Failed to introspect Class [com.quin.faithtag.common.datasource.DynamicDataSourceAutoConfiguration] from ClassLoader [jdk.internal.loader.ClassLoaders$AppClassLoader@63947c6b] at org.springframework.util.ReflectionUtils.getDeclaredMethods(ReflectionUtils.java:483) at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:360) at org.springframework.util.ReflectionUtils.getUniqueDeclaredMethods(ReflectionUtils.java:417) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.lambda$getTypeForFactoryMethod$1(AbstractAutowireCapableBeanFactory.java:750) at java.base/java.util.concurrent.ConcurrentHashMap.computeIfAbsent(ConcurrentHashMap.java:1708) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getTypeForFactoryMethod(AbstractAutowireCapableBeanFactory.java:749) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.determineTargetType(AbstractAutowireCapableBeanFactory.java:682) at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.predictBeanType(AbstractAutowireCapableBeanFactory.java:653) at org.springframework.beans.factory.support.AbstractBeanFactory.isFactoryBean(AbstractBeanFactory.java:1687) at org.springframework.beans.factory.support.DefaultListableBeanFactory.doGetBeanNamesForType(DefaultListableBeanFactory.java:562) at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanNamesForType(DefaultListableBeanFactory.java:534) at org.springframework.boot.autoconfigure.condition.OnBeanCondition.collectBeanNamesForType(OnBeanCondition.java:247) at org.springframework.boot.autoconfigure.condition.OnBeanCondition.getBeanNamesForType(OnBeanCondition.java:240) at org.springframework.boot.autoconfigure.condition.OnBeanCondition.getBeanNamesForType(OnBeanCondition.java:230) at org.springframework.boot.autoconfigure.condition.OnBeanCondition.getMatchingBeans(OnBeanCondition.java:183) at org.springframework.boot.autoconfigure.condition.OnBeanCondition.getMatchOutcome(OnBeanCondition.java:158) at org.springframework.boot.autoconfigure.condition.SpringBootCondition.matches(SpringBootCondition.java:47) ... 17 common frames omitted Caused by: java.lang.NoClassDefFoundError: com/baomidou/dynamic/datasource/provider/DynamicDataSourceProvider at java.base/java.lang.Class.getDeclaredMethods0(Native Method) at java.base/java.lang.Class.privateGetDeclaredMethods(Class.java:3402) at java.base/java.lang.Class.getDeclaredMethods(Class.java:2504) at org.springframework.util.ReflectionUtils.getDeclaredMethods(ReflectionUtils.java:465) ... 33 common frames omitted Caused by: java.lang.ClassNotFoundException: com.baomidou.dynamic.datasource.provider.DynamicDataSourceProvider at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader.java:641) at java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:188) at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:525) ... 37 common frames omitted Disconnected from the target VM, address: '127.0.0.1:8853', transport: 'socket' Process finished with exit code 1
最新发布
09-30
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值