我有一个弹簧批量管理应用程序,我在META-INF / spring / jobs /文件夹中有作业xmls。
作业初始化失败,出现以下错误..
如果我将jobs文件夹更改为" bootstrap" ...应用程序正常工作......但是工作没有注册..有没有人遇到过这样的问题。
我的理解是每个工作都有不同的应用程序上下文。但是,例外情况是我在' root'上下文
Caused by: org.springframework.context.ApplicationContextException: Cannot reinitialize with different application context: current one is [Root WebApplicationContext: startup date [Mon Jul 28 19:08:01 GMT+05:30 2014]; root of context hierarchy], passed-in one is [ResourceXmlApplicationContext:file:/Users/thrinath.d/abc/alliances/alliances/alliances-batch/target/alliances-batch/WEB-INF/classes/META-INF/spring/batch/jobs/alliances-campaign-retry-process.xml]
at org.springframework.context.support.ApplicationObjectSupport.setApplicationContext(ApplicationObjectSupport.java:78)
at org.springframework.context.support.ApplicationContextAwareProcessor.invokeAwareInterfaces(ApplicationContextAwareProcessor.java:117)
at org.springframework.context.support.ApplicationContextAwareProcessor.postProcessBeforeInitialization(ApplicationContextAwareProcessor.java:92)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyBeanPostProcessorsBeforeInitialization(AbstractAutowireCapableBeanFactory.java:394)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java:1448)
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:519)
... 62 more
2014年7月28日下午7:08:07 org.apache.catalina.core.ApplicationContext log
示例作业xml包含在
下面<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:batch="http://www.springframework.org/schema/batch"
xmlns:task="http://www.springframework.org/schema/task"
xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/batch http://www.springframework.org/schema/batch/spring-batch.xsd
http://www.springframework.org/schema/task http://www.springframework.org/schema/task/spring-task-3.0.xsd">
<!--Imports-->
<import resource="classpath*:META-INF/spring/batch/alliances-batch-context.xml"/>
<import resource="classpath*:META-INF/spring/batch/global-job-context.xml"/>
<!--Imports Ends-->
<!--Job schedule Beans-->
<task:scheduler id="alliancesCampaignRetryScheduler" pool-size="5"/>
<task:scheduled-tasks scheduler="alliancesCampaignRetryScheduler">
<task:scheduled ref="alliancesCampaignRetrySchedulingLauncher" method="launch" fixed-delay="1800000"/>
</task:scheduled-tasks>
<bean id="alliancesCampaignRetrySchedulingLauncher"
class="com.abc.alliances.batch.SynchronousSingletonJobLauncher">
<constructor-arg name="newJob" ref="alliances-campaign-retry-process" />
<constructor-arg name="newJobLauncher" ref="jobLauncher"/>
<constructor-arg name="newJobExplorer" ref="jobExplorer"/>
</bean>
<!--Job schedule Beans End-->
<!--Job Def-->
<batch:job id="alliances-campaign-retry-process" incrementer="incrementer">
<batch:step id="campaignRetryProcessor" >
<batch:tasklet ref="alliancesCampaignRetryProcessor"/>
</batch:step>
<batch:listeners>
<batch:listener ref="skipLogger"/>
</batch:listeners>
</batch:job>
<!--Job Def Ends-->
<!--Processor Defs-->
<bean id="alliancesCampaignRetryProcessor" class="com.abc.alliances.batch.processors.AlliancesPromoRetryProcessor">
<constructor-arg name="campaignManager" ref="campaignManager" />
<constructor-arg name="campaignPipelineManager" ref="campaignPipelineManager" />
<constructor-arg name="campaignRetryQueueDao" ref="campaignRetryQueueDao"/>
<constructor-arg name="maxRetryCount" value="5"/>
</bean>
<!--Processor Defs Ends-->
web.xml内容附在
下面<?xml version="1.0" encoding="ISO-8859-1"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd" version="2.4">
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:/org/springframework/batch/admin/web/resources/webapp-config.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<filter>
<filter-name>shallowEtagHeaderFilter</filter-name>
<filter-class>org.springframework.web.filter.ShallowEtagHeaderFilter</filter-class>
</filter>
<filter>
<filter-name>hiddenHttpMethodFilter</filter-name>
<filter-class>org.springframework.web.filter.HiddenHttpMethodFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>shallowEtagHeaderFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>hiddenHttpMethodFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<servlet>
<servlet-name>Batch Servlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath*:/org/springframework/batch/admin/web/resources/servlet-config.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Batch Servlet</servlet-name>
<url-pattern>/*</url-pattern>
</servlet-mapping>
答案 0 :(得分:0)
我评论了以下几行,这些行包含在作业xml [通过其他文件导入]中,并且它开始工作..可以让一些人认为背后的解释
<mvc:annotation-driven/>
<context:annotation-config/>