繁体   English   中英

当我尝试实例化 JobOperator 时,抛出了 ClassNotFoundException。 (org.apache.commons.dbcp2.BasicDataSource)

[英]When I tried to instantiate JobOperator then a ClassNotFoundException was thrown. (org.apache.commons.dbcp2.BasicDataSource)

我从一个基本的 Spring 批处理入门示例开始。 我只添加了一条指令来停止工作,但我在运行时遇到异常。

https://github.com/brunogcarneiro/spring-batch-error/blob/main/src/main/java/com/example/batchprocessing/JobCompletionNotificationListener.java

@Override
public void beforeJob(JobExecution jobExecution){
    log.info("Job starting!");
    BatchRuntime.getJobOperator().stop(jobExecution.getId());
    log.info("Job stoped!");
}

当我调用getJobOperato() 时抛出异常。 一旦我使用spring-boot-starter-batch,我就无法弄清楚为什么会发生这种情况。

完整的源代码可以在以下位置找到: https://github.com/brunogcarneiro/spring-batch-error

堆栈跟踪是:

2021-01-14 15:09:01.963 错误 126675 --- [main] osbatch.core.job.AbstractJob >:执行作业时遇到致命错误

java.util.ServiceConfigurationError: javax.batch.operations.JobOperator: Provider >org.springframework.batch.core.jsr.launch.JsrJobOperator could not be instantiated at java.base/java.util.ServiceLoader.fail(ServiceLoader.java: 581) ~[na:na] at java.base/java.util.ServiceLoader$ProviderImpl.newInstance(ServiceLoader.java:803) ~>[na:na] at java.base/java.util.ServiceLoader$ProviderImpl.get (ServiceLoader.java:721) ~[na:na] at java.base/java.util.ServiceLoader$3.next(ServiceLoader.java:1394) ~[na:na] at javax.batch.runtime.BatchRuntime$1.run (BatchRuntime.java:52) ~[javax.batch-api-1.0.jar:1.0] 在 javax.batch.runtime.BatchRuntime$1.run(BatchRuntime.Z93F725A07C 889F448B33D21F46Z:47) ~[javax.batch-api-1.0.jar:1.0] at java.base/java.security.AccessController.doPrivileged(Native Method) ~[na:na] at javax.batch.runtime.BatchRuntime.getJobOperator (BatchRuntime.java:47) ~[javax.batch-api->1.0.jar:1.0] at >com.example.batchprocessing.JobCompletionNotificationListener.beforeJob(JobCompletionNotificationListener.java:31) ~[main/:na] at >org .springframework.batch.core.listener.CompositeJobExecutionListener.beforeJob(CompositeJobExecutionListener.java:73) ~[spring-batch-core-4.2.1.RELEASE.jar:4.2.1.RELEASE] at org.springframework.batch.core. job.AbstractJob.execute(AbstractJob.java:316) ~[spring->batch-core-4.2.1.RELEASE.jar:4.2.1.RELEASE] at org.suppospringframework.launch. rt.SimpleJobLauncher$1.run(SimpleJobLauncher.java:147) ~[spring-batch-core-4.2.1.RELEASE.jar:4.2.1.RELEASE.Task org. java:50) ~[spring-core-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.batch.core.launch.support.SimpleJobLauncher.run(SimpleJobLauncher.java:140) ~[spring -batch-core-4.2.1.RELEASE.jar:4.2.1.RELEASE] at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:na] at java.base/jdk. internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)~[na:na] 在 java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.Z93F725 A07423FE1C889F448B33D21F46Z:43) ~[na:na] at java.base/java.lang.reflect.Method.invoke(Method.java:566) ~[na:na] at org.springframework.aop.support.AopUtils.invokeJoinpointUsingReflection( AopUtils.java:344) ~[spring-aop-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.aop.framework.ReflectiveMethodInvocation.invokeJoinpoint(ReflectiveMethodInvocation.java:198) ~[spring-aop -5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:163) ~[spring-aop-5.2.2.RELEASE.jar:5.2. 2.RELEASE] 在 org.springframework.batch.core.configuration.annotation.SimpleBatchConfiguration$PassthruAdvice.invoke(SimpleBatchConfiguration.java:127) ~[spring-batch-c ore-4.2.1.RELEASE.jar:4.2.1.RELEASE] at org.springframework.aop.framework.ReflectiveMethodInvocation.proceed(ReflectiveMethodInvocation.java:186) ~[spring-aop-5.2.2.RELEASE.jar:5.2 .2.RELEASE] at org.springframework.aop.framework.JdkDynamicAopProxy.invoke(JdkDynamicAopProxy.java:212) ~[spring-aop-5.2.2.RELEASE.jar:5.2.2.RELEASE] at com.sun.proxy .$Proxy46.run(Unknown Source) ~[na:na] at org.springframework.boot.autoconfigure.batch.JobLauncherCommandLineRunner.execute(JobLauncherCommandLineRunner.java:192) ~[spring-boot-autoconfigure-2.2.2.RELEASE。 jar:2.2.2.RELEASE] 在 org.springframework.boot.autoconfigure.batch.JobLauncherCommandLineRunner.executeLocalJobs(JobLauncherCommandLineRunner.java:166) ~[spring-auto-boot-boot igure-2.2.2.RELEASE.jar:2.2.2.RELEASE] at org.springframework.boot.autoconfigure.batch.JobLauncherCommandLineRunner.launchJobFromProperties(JobLauncherCommandLineRunner.java:153) ~[spring-boot-autoconfigure-2.2.2.RELEASE .jar:2.2.2.RELEASE] at org.springframework.boot.autoconfigure.batch.JobLauncherCommandLineRunner.run(JobLauncherCommandLineRunner.java:148) ~[spring-boot-autoconfigure-2.2.2.RELEASE.jar:2.2.2.发布] 在 org.springframework.boot.SpringApplication.callRunner(SpringApplication.java:784) ~[spring-boot-2.2.2.RELEASE.jar:2.2.2.SpringApplication.call] 在 org.springApplication.call. SpringApplication.java:768) ~[spring-boot-2.2.2.RELEASE.jar:2.2.2.RELEASE] at org.springframework.boot.SpringAppli cation.run(SpringApplication.java:322) ~[spring-boot-2.2.2.RELEASE.jar:2.2.2.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1226) ~[spring -boot-2.2.2.RELEASE.jar:2.2.2.RELEASE] at org.springframework.boot.SpringApplication.run(SpringApplication.java:1215) ~[spring-boot-2.2.2.RELEASE.jar:2.2. 2.RELEASE] 在 com.example.batchprocessing.BatchProcessingApplication.main(BatchProcessingApplication.java:10) ~[main/:na] 引起:org.springframework.beans.factory.BeanCreationException:错误创建名称'设置 bean 属性“dataSource”时无法解析对 bean“dataSource”的引用; nested exception is org.springframework.beans.factory.CannotLoadBeanClassException: Cannot find class [org.apache.commons.dbcp2.BasicDataSource] for bean with name 'dataSource' defined in class path resource [jsrBaseContext.xml]; nested exception is java.lang.ClassNotFoundException: org.apache.commons.dbcp2.BasicDataSource at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:342) ~[spring-beans-5.2.2.RELEASE .jar:5.2.2.RELEASE] 原因:org.springframework.beans.factory.BeanCreationException:创建名为“jobRepository”的bean时出错:设置bean属性“dataSource”时无法解析对bean“dataSource”的引用; nested exception is org.springframework.beans.factory.CannotLoadBeanClassException: Cannot find class [org.apache.commons.dbcp2.BasicDataSource] for bean with name 'dataSource' defined in class path resource [jsrBaseContext.xml]; 嵌套异常是 java.lang.ClassNotFoundException: org.apache.commons.dbcp2.BasicDataSource

at org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveValueIfNecessary(BeanDefinitionValueResolver.java:113) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory. support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1699) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java :1444) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at >org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(Abstr>actAutowireCapableBeanFactory.java:594) ~[spring -beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] 在 > org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(Abstrac>tAutowireCapableBeanFactory.java:517) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory .support.AbstractBeanFactory.lambda$doGetBean$0(AbstractBeanFactory.java:323) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton (DefaultSingletonBeanRegistry.java:222) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:321) ~[ spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBean Factory.java:202) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:860) ~[spring -beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:878) ~[spring-context-5.2.2.RELEASE.jar: 5.2.2.RELEASE] at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:550) ~[spring-context-5.2.2.RELEASE.Z68995FCBF432492D15484Zorg.204A9D2250] context.support.GenericXmlApplicationContext.(GenericXmlApplicationContext.java:71) ~[spring-context-5.2.2.RE LEASE.jar:5.2.2.RELEASE] at org.springframework.batch.core.jsr.launch.JsrJobOperator$BaseContextHolder.(JsrJobOperator.java:831) ~[spring-batch-core-4.2.1.RELEASE.jar: 4.2.1.RELEASE] at >org.springframework.batch.core.jsr.launch.JsrJobOperator$BaseContextHolder.getInstance(JsrJobOp>erator.java:839) ~[spring-batch-core-4.2.1.RELEASE.Z2689954FCDAC43249 4.2.1.RELEASE] 在 org.springframework.batch.core.jsr.launch.JsrJobOperator.(JsrJobOperator.java:163) >~[spring-batch-core-4.2.1.RELEASE.Z68995FCBF4342A2492D15484D0.D15484D0. ] at java.base/jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) >~[na:na] at >java.base/jdk.internal.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) ~[ na:na] 在 >jav a.base/jdk.internal.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) ~[na:na] at java.base/java.lang.reflect.Constructor.newInstance(Constructor.java:490) ~[na :na] 在 java.base/java.util.ServiceLoader$ProviderImpl.newInstance(ServiceLoader.java:779) ~[na:na]...省略了 33 个常见帧 原因:org.springframework.beansfactory.找不到 class [org.apache.commons.dbcp2.BasicDataSource] 用于在 class 路径资源 [jsrBaseContext.xml] 中定义的名称为“dataSource”的 bean; nested exception is java.lang.ClassNotFoundException: org.apache.commons.dbcp2.BasicDataSource Caused by: org.springframework.beans.factory.CannotLoadBeanClassException: Cannot find class [org.apache.commons.dbcp2.BasicDataSource] for bean with name ' dataSource' 在 class 路径资源 [jsrBaseContext.xml] 中定义; 嵌套异常是 java.lang.ClassNotFoundException: org.apache.commons.dbcp2.BasicDataSource

在 org.springframework.beans.factory.support.AbstractBeanFactory.resolveBeanClass(AbstractBeanFactory.java:1476) ~[spring-beans-5.2.2.RELEASE.jar:5.2 support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:489) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.AbstractBeanFactory.lambda$doGetBean$0( AbstractBeanFactory.java:323) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:222) ~[spring -beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean( AbstractBeanFactory.java:321) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:202) ~[spring -beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at >org.springframework.beans.factory.support.BeanDefinitionValueResolver.resolveReference(BeanDefinitionValueResolver.java:330) ~[spring-beans-5.2.2.RELEASE .jar:5.2.2.RELEASE]... 54 common frames omitted Caused by: java.lang.ClassNotFoundException: org.apache.commons.dbcp2.BasicDataSource at java.base/jdk.internal.loader.BuiltinClassLoader.loadClass(BuiltinClassLoader .java:581) ~[na:na] 引起:java.lang.ClassNotFoundException: org. apache.commons.dbcp2.BasicDataSource

at >java.base/jdk.internal.loader.ClassLoaders$AppClassLoader.loadClass(ClassLoaders.java:178) ~>[na:na] at java.base/java.lang.ClassLoader.loadClass(ClassLoader.java:522) ~[na:na] at java.base/java.lang.Class.forName0(Native Method) ~[na:na] at java.base/java.lang.Class.forName(Class.java:398) ~[na :na] at org.springframework.util.ClassUtils.forName(ClassUtils.java:277) ~[spring-core-5.2.2.RELEASE.jar:5.2.2.RELE. .AbstractBeanDefinition.resolveBeanClass(AbstractBeanDefinition.java:456)~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE.factory] at org.org. eanFactory.doResolveBeanClass(AbstractBeanFactory.java:1541) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE] at org.springframework.beans.factory.support.AbstractBeanFactory.resolveBeanClass(AbstractBeanFactory.java:1468 ) ~[spring-beans-5.2.2.RELEASE.jar:5.2.2.RELEASE]...省略60个常用框架

2021-01-14 15:09:02.013 INFO 126675 --- [main] osbc.l.support.SimpleJobLauncher:作业:[FlowJob:[name=importUserJob]] 使用以下参数完成:[{run.id=1 }] 和以下状态: [FAILED] in 9s845ms 2021-01-14 15:09:02.016 INFO 126675 --- [main] com.zaxxer.hikari.HikariDataSource: HikariPool-1 - 关闭启动... 2021-01 -14 15:09:02.019 INFO 126675 --- [主] com.zaxxer.hikari.HikariDataSource >:HikariPool-1 - 关闭完成。

请在您的 build.gradle 中添加以下内容,它将通过 go。

compile group: 'org.apache.commons', name: 'commons-dbcp2', version: '2.8.0'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM