Ошибка загрузки Spring bean с использованием spring-data-mongodb

Мы используем Spring версии 3.2.0 и теперь представляем spring-data-mongodb версии 1.4.0 в кодовой базе. Я попытался написать новый файл конфигурации spring (mongo-config.xml), в то время как определял только bean-компоненты, связанные с mongodb.

Моя конфигурация Spring выглядит следующим образом:

    <?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:util="http://www.springframework.org/schema/util"
    xmlns:mongo="http://www.springframework.org/schema/data/mongo"
    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
        http://www.springframework.org/schema/util http://www.springframework.org/schema/util/spring-util-3.2.xsd
        http://www.springframework.org/schema/data/mongo http://www.springframework.org/schema/data/mongo/spring-mongo-1.4.xsd
        http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd">

<mongo:mongoid="replicaSetMongo"replica-set="localhost:10901,localhost:10902">
<mongo:optionsconnections-per-host="8"
ssl="false" />
</mongo:mongo>

<mongo:db-factoryid="xmlLogDbFactory"
mongo-ref="replicaSetMongo"
dbname="logs"
username="logs_owner"
password="logs_owner" />

<mongo:mapping-converter>
<mongo:custom-converters>
<mongo:converter>
<beanclass="com.utils.mongodb.dao.impl.SspLogsWriteConver ter"/>
</mongo:converter>
</mongo:custom-converters>
</mongo:mapping-converter>

<beanid="xmlLogTemplate"class="org.springframework.data.mongodb.core.MongoTempla te">
<constructor-argname="mongoDbFactory"ref="xmlLogDbFactory"/>
<constructor-argname="mongoConverter"ref="mappingConverter"/>
<propertyname="writeConcern">
<util:constantstatic-field="com.mongodb.WriteConcern.UNACKNOWLEDGED"/>
</property>
</bean>

</beans>

Я развернул приложение на JBoss. Но JBoss выдавал ошибки при запуске следующим образом. Может кто-нибудь помочь мне, что происходит не так? Есть ли несоответствие между версией spring и версией spring-mongodb? Я заметил, что в трассировке исключения упоминается банка spring-beans-3.2.0, хотя проблема связана с mongo-config.xml.

Caused by: org.springframework.beans.factory.parsing.BeanDefi nitionParsingException: Configuration problem: Failed to import bean definitions from relative location [mongo-config.xml]
Offending resource: class path resource [spring/commonUtil-config.xml]; nested exception is org.springframework.beans.factory.BeanDefinitionSt oreException: Unexpected exception parsing XML document from class path resource [spring/mongo-config.xml]; nested exception is org.springframework.beans.FatalBeanException: Invalid NamespaceHandler class [org.springframework.data.mongodb.config.MongoNames paceHandler] for namespace [http://www.springframework.org/schema/data/mongo]: problem with handler class file or dependent class; nested exception is java.lang.NoClassDefFoundError: org/springframework/data/repository/config/RepositoryConfigurationExtension
at org.springframework.beans.factory.parsing.FailFast ProblemReporter.error(FailFastProblemReporter.java :68) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.parsing.ReaderCo ntext.error(ReaderContext.java:85) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.parsing.ReaderCo ntext.error(ReaderContext.java:76) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.DefaultBeanD efinitionDocumentReader.importBeanDefinitionResour ce(DefaultBeanDefinitionDocumentReader.java:271) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.DefaultBeanD efinitionDocumentReader.parseDefaultElement(Defaul tBeanDefinitionDocumentReader.java:196) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.DefaultBeanD efinitionDocumentReader.parseBeanDefinitions(Defau ltBeanDefinitionDocumentReader.java:181) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.DefaultBeanD efinitionDocumentReader.doRegisterBeanDefinitions( DefaultBeanDefinitionDocumentReader.java:140) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.DefaultBeanD efinitionDocumentReader.registerBeanDefinitions(De faultBeanDefinitionDocumentReader.java:111) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.XmlBeanDefin itionReader.registerBeanDefinitions(XmlBeanDefinit ionReader.java:493) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.XmlBeanDefin itionReader.doLoadBeanDefinitions(XmlBeanDefinitio nReader.java:390) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.XmlBeanDefin itionReader.loadBeanDefinitions(XmlBeanDefinitionR eader.java:334) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.XmlBeanDefin itionReader.loadBeanDefinitions(XmlBeanDefinitionR eader.java:302) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
at org.springframework.beans.factory.xml.DefaultBeanD efinitionDocumentReader.importBeanDefinitionResour ce(DefaultBeanDefinitionDocumentReader.java:255) [spring-beans-3.2.0.RELEASE.jar:3.2.0.RELEASE]
... 36 more

person illcar    schedule 09.03.2014    source источник
comment
Кажется, вам не хватает этого класса org/springframework/data/repository/config/RepositoryConfigurationExtension в вашем пути к классам.   -  person Sotirios Delimanolis    schedule 10.03.2014
comment
@Sotirios: этот класс является частью spring-data-mongodb-1.4.0.RELEASE.jar, который уже присутствует в моей папке WEB-INF/lib.   -  person illcar    schedule 10.03.2014
comment
Нет, это из spring-data-commons   -  person Ori Dar    schedule 10.03.2014
comment
Я думаю, проблема в том, что этот класс является частью более чем одной банки. Как мне это решить? jar tvf ../standalone/deployments/app-ws.war/WEB-INF/lib/spring-data-mongodb-1.4.0.RELEASE.jar | grep RepositoryConfigurationExtension 3139 Пт, 08 февраля, 04:14:40 PST 2013 org/springframework/data/mongodb/repository/config/MongoRepositoryConfigurationExtension.class   -  person illcar    schedule 10.03.2014


Ответы (1)


Эта проблема решена сейчас. Я понял, что когда maven загрузил jar spring-data-mongodb версии 1.4, в моем репозитории был загружен еще один jar: spring-data-commons версии 1.7.

Я скопировал эту вторую банку в свою папку WEB-INF/lib, и приложение заработало.

person illcar    schedule 11.03.2014