【问题标题】:Cannot reinitialize with different application context无法使用不同的应用程序上下文重新初始化
【发布时间】:2016-07-09 03:25:17
【问题描述】:

我正在使用Mule和Spring Integration实现发送短信功能,下面是spring xml配置:

    <?xml version="1.0" encoding="UTF-8"?>

<mule xmlns="http://www.mulesoft.org/schema/mule/core" xmlns:doc="http://www.mulesoft.org/schema/mule/documentation"
    xmlns:spring="http://www.springframework.org/schema/beans" version="EE-3.7.2"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:int="http://www.springframework.org/schema/integration"
    xmlns:oxm="http://www.springframework.org/schema/oxm" xmlns:int-http="http://www.springframework.org/schema/integration/http"
    xmlns:context="http://www.springframework.org/schema/context"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-current.xsd
http://www.mulesoft.org/schema/mule/core http://www.mulesoft.org/schema/mule/core/current/mule.xsd
http://www.springframework.org/schema/integration/http http://www.springframework.org/schema/integration/http/spring-integration-http.xsd
        http://www.springframework.org/schema/integration http://www.springframework.org/schema/integration/spring-integration.xsd
        http://www.springframework.org/schema/oxm http://www.springframework.org/schema/oxm/spring-oxm.xsd
        http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-current.xsd">
<spring:beans>

    <context:component-scan base-package="com.scholes.sf.message" />

    <oxm:jaxb2-marshaller id="sfRequestMarshaller">
        <oxm:class-to-be-bound name="com.scholes.sf.message.bean.SFSendSMSRequest" />
        <oxm:class-to-be-bound name="com.scholes.sf.message.bean.SFVerifySMSRequest" />
    </oxm:jaxb2-marshaller>

    <!-- send SMS -->
    <int:channel id="sendOobSmsResponseJsonChannel" />

    <int:channel id="sendOobSmsResponseObjectChannelOOB" />

    <int:channel id="sendOobSmsResponseObjectChannelSF" />

    <int:channel id="sendOobSmsRequestChannel" />

    <int:channel id="sendOobSmsResponseXmlChannel" />
    <int:channel id="verifyOobSmsResponseXmlChannel" />

    <int:channel id="verifyOobSmsRequestChannel" />

    <int:channel id="verifyOobSmsResponseObjectChannelSF" />

    <int:channel id="verifyOobSmsResponseObjectChannelOOB" />

    <int:channel id="verifyOobSmsResponseJsonChannel" />

    <int:object-to-json-transformer
        input-channel="sendOobSmsResponseObjectChannelOOB" output-channel="sendOobSmsResponseJsonChannel">
    </int:object-to-json-transformer>

    <int:transformer input-channel="sendOobSmsResponseObjectChannelSF"
        output-channel="sendOobSmsResponseObjectChannelOOB" ref="oobSendSMSTransformer" />

    <int:transformer input-channel="sendOobSmsResponseXmlChannel"
        output-channel="sendOobSmsResponseObjectChannelSF" ref="sfSendResponseUnmarshaller" />

    <int:transformer input-channel="sendOobSmsRequestChannel"
        output-channel="sendOobSmsResponseXmlChannel" ref="sfSendSmsTransformer" />
    <spring:bean id="sfSendSmsTransformer" class="com.scholes.sf.message.transformer.SFSendSMSTransformer" />

    <int:channel id="sendOobSmsResponseObjectChannel" />

    <spring:bean id="sfSendResponseUnmarshaller"
        class="org.springframework.integration.xml.transformer.UnmarshallingTransformer">
        <spring:constructor-arg>
            <oxm:jaxb2-marshaller id="sfSendRequestMarshaller">
                <oxm:class-to-be-bound name="com.scholes.sf.message.bean.SFSendSMSResponse" />
            </oxm:jaxb2-marshaller>
        </spring:constructor-arg>
    </spring:bean>

    <spring:bean id="oobSendSMSTransformer" class="com.scholes.sf.message.transformer.OOBSendSMSTransformer" /> 

    <!-- verify SMS -->
    <int:transformer input-channel="verifyOobSmsRequestChannel"
        output-channel="verifyOobSmsResponseXmlChannel" ref="sfVerifySmsTransformer" />
    <spring:bean id="sfVerifySmsTransformer" class="com.scholes.sf.message.transformer.SFVerifySMSTransformer" />

    <int:channel id="verifyOobSmsResponseObjectChannel" />

    <spring:bean id="sfVerifyResponseUnmarshaller"
        class="org.springframework.integration.xml.transformer.UnmarshallingTransformer">
        <spring:constructor-arg>
            <oxm:jaxb2-marshaller id="sfVerifyRequestMarshaller">
                <oxm:class-to-be-bound name="com.scholes.sf.message.bean.SFVerifySMSResponse" />
            </oxm:jaxb2-marshaller>
        </spring:constructor-arg>
    </spring:bean>

    <int:transformer input-channel="verifyOobSmsResponseXmlChannel"
        output-channel="verifyOobSmsResponseObjectChannelSF" ref="sfVerifyResponseUnmarshaller" />

    <int:transformer input-channel="verifyOobSmsResponseObjectChannelSF"
        output-channel="verifyOobSmsResponseObjectChannelOOB" ref="oobVerifySMSTransformer" />
    <spring:bean id="oobVerifySMSTransformer" class="com.scholes.sf.message.transformer.OOBVerifySMSTransformer" />

    <int:object-to-json-transformer
        input-channel="verifyOobSmsResponseObjectChannelOOB" output-channel="verifyOobSmsResponseJsonChannel">
    </int:object-to-json-transformer>

    <context:property-placeholder location="sms/oob-config.properties"/>



    </spring:beans>
</mule>

似乎尝试初始化第二个 spring-integration context ,所以出现以下错误:

WARN 2016-03-22 17:21:37,388 [main] org.mule.config.spring.MuleArtifactContext:上下文初始化期间遇到异常 - 取消刷新尝试 org.springframework.beans.factory.BeanCreationException:创建名为“integrationRequestMappingHandlerMapping”的bean时出错:bean初始化失败;嵌套异常是 org.springframework.context.ApplicationContextException:无法使用不同的应用程序上下文重新初始化:当前是 [org.mule.config.spring.MuleDomainContext@1825085:启动日期 [Tue Mar 22 17:21:29 CST 2016];上下文层次结构的根],传入一个是[org.mule.config.spring.MuleArtifactContext@14f3da4:启动日期[Tue Mar 22 17:21:33 CST 2016];父:org.mule.config.spring.MuleDomainContext@1825085] 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:547) ~[spring-beans-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:476) ~[spring-beans-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:303) ~[spring-beans-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:230) ~[spring-beans-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:299) ~[spring-beans-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:194) ~[spring-beans-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:753) ~[mule-module-spring-config-3.7.2.jar:4.1.6.RELEASE] 在 org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:757) ~[spring-context-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:480) ~[spring-context-4.1.6.RELEASE.jar:4.1.6.RELEASE] 在 org.mule.config.spring.SpringRegistry.doInitialise(SpringRegistry.java:108) ~[mule-module-spring-config-3.7.2.jar:3.7.2]

哪位高手可以帮忙分析一下这个问题?如果我不包括这个 xml ,那就没问题了。如何让 SI 和 Spring 协同工作?

【问题讨论】:

    标签: java spring spring-mvc mule


    【解决方案1】:

    这是根本原因

    Cannot reinitialize with different application context: current one is
    [org.mule.config.spring.MuleDomainContext@1825085: 
    startup date [Tue Mar 22 17:21:29 CST 2016]; root of context hierarchy], 
    passed-in one is [org.mule.config.spring.MuleArtifactContext@14f3da4: 
    startup date [Tue Mar 22 17:21:33 CST 2016]; 
    parent: org.mule.config.spring.MuleDomainContext@1825085] at 
    org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:547)
    

    检查您的 XML 命名空间。也许您只是错误地复制粘贴了它,然后您的上下文就发生了冲突。

    还要检查您的 integrationRequestMappingHandlerMapping bean 定义。碰巧它是由不同的上下文初始化的。请附上它的定义。

    【讨论】:

      【解决方案2】:

      发生这种情况是因为您将 mule spring 配置与 SI 混合在一起,其中某些组件无法识别。您可以尝试分离 SI 配置,然后将其导入 mule 配置吗?如下:

      <?xml version="1.0" encoding="UTF-8"?>
        <mule xmlns=http://www.mulesoft.org/schema/mule/c... ....>
           <spring:beans>
              <spring:import resource="si-config.xml" />
           </spring:beans>
      

      另外,请通过比较EE 3.7.2和你使用的SI使用的spring框架版本来检查你是否使用了正确的Spring Integration版本。

      【讨论】:

      • 现在我只是在我的 java 源代码中以编程方式加载 si-config.xml 来解决这个问题。
      猜你喜欢
      • 2012-01-19
      • 2021-07-13
      • 2010-09-23
      • 1970-01-01
      • 2011-03-06
      • 2016-02-11
      • 2016-12-13
      • 1970-01-01
      相关资源
      最近更新 更多