无法启动spring-batch-admin应用程序

时间:2014-07-28 13:47:34

标签: java spring spring-mvc spring-batch spring-batch-admin

我有一个弹簧批量管理应用程序,我在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>

1 个答案:

答案 0 :(得分:0)

我评论了以下几行,这些行包含在作业xml [通过其他文件导入]中,并且它开始工作..可以让一些人认为背后的解释

<mvc:annotation-driven/>
<context:annotation-config/>