낙타 1.5.0을 시작할 수 없습니다
-
19-08-2019 - |
문제
나는 낙타 예 "Camel-Axample-Spring-JMS"를 실행하려고합니다 (또한 http://activemq.apache.org/camel/tutorial-jmsremoting.html). 그러나 "org.apache.camel.spring.main"클래스를 사용하여 낙타를 시작하려고하면 오류가 발생합니다.
"구성 문제 : XML 스키마 네임 스페이스 용 스프링 네임 스페이스 핸들러를 찾을 수 없습니다.http://activemq.apache.org/schema/core"
참고 : Maven Command "MVN Exec : Java -pcamelserver"를 사용할 때 예제를 잘 실행할 수 있습니다.
누군가가 이것의 원인을 이해하도록 도와 줄 수 있습니까? 잠재적 결의 힌트도 아프지 않을 것입니다 :)
++++++ 오류 스택 +++++
Dec 4, 2008 12:45:01 PM org.apache.camel.util.MainSupport doStart
INFO: Apache Camel 1.5.0 starting
Dec 4, 2008 12:45:01 PM org.springframework.context.support.AbstractApplicationContext prepareRefresh
INFO: Refreshing org.springframework.context.support.ClassPathXmlApplicationContext@1ac3c08: display name [org.springframework.context.support.ClassPathXmlApplicationContext@1ac3c08]; startup date [Thu Dec 04 12:45:01 EST 2008]; root of context hierarchy
Dec 4, 2008 12:45:01 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from file [C:\dev\camel-example-spring-jms\bin\META-INF\spring\camel-server-aop.xml]
Dec 4, 2008 12:45:02 PM org.springframework.beans.factory.xml.XmlBeanDefinitionReader loadBeanDefinitions
INFO: Loading XML bean definitions from file [C:\dev\camel-example-spring-jms\bin\META-INF\spring\camel-server.xml]
Dec 4, 2008 12:45:03 PM org.apache.camel.util.MainSupport run
SEVERE: Failed: org.springframework.beans.factory.parsing.BeanDefinitionParsingException: Configuration problem: Failed to import bean definitions from relative location [camel-server.xml]
Offending resource: file [C:\dev\camel-example-spring-jms\bin\META-INF\spring\camel-server-aop.xml]; nested exception is org.springframework.beans.factory.parsing.BeanDefinitionParsingException: Configuration problem: Unable to locate Spring NamespaceHandler for XML schema namespace [http://activemq.apache.org/schema/core]
Offending resource: file [C:\dev\camel-example-spring-jms\bin\META-INF\spring\camel-server.xml]
org.springframework.beans.factory.parsing.BeanDefinitionParsingException: Configuration problem: Failed to import bean definitions from relative location [camel-server.xml]
Offending resource: file [C:\dev\camel-example-spring-jms\bin\META-INF\spring\camel-server-aop.xml]; nested exception is org.springframework.beans.factory.parsing.BeanDefinitionParsingException: Configuration problem: Unable to locate Spring NamespaceHandler for XML schema namespace [http://activemq.apache.org/schema/core]
Offending resource: file [C:\dev\camel-example-spring-jms\bin\META-INF\spring\camel-server.xml]
at org.springframework.beans.factory.parsing.FailFastProblemReporter.error(FailFastProblemReporter.java:68)
at org.springframework.beans.factory.parsing.ReaderContext.error(ReaderContext.java:85)
at org.springframework.beans.factory.parsing.ReaderContext.error(ReaderContext.java:76)
at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.importBeanDefinitionResource(DefaultBeanDefinitionDocumentReader.java:201)
at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.parseDefaultElement(DefaultBeanDefinitionDocumentReader.java:147)
at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.parseBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:132)
at org.springframework.beans.factory.xml.DefaultBeanDefinitionDocumentReader.registerBeanDefinitions(DefaultBeanDefinitionDocumentReader.java:92)
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.registerBeanDefinitions(XmlBeanDefinitionReader.java:507)
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.doLoadBeanDefinitions(XmlBeanDefinitionReader.java:398)
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:342)
at org.springframework.beans.factory.xml.XmlBeanDefinitionReader.loadBeanDefinitions(XmlBeanDefinitionReader.java:310)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:143)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:178)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:149)
at org.springframework.beans.factory.support.AbstractBeanDefinitionReader.loadBeanDefinitions(AbstractBeanDefinitionReader.java:212)
at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:113)
at org.springframework.context.support.AbstractXmlApplicationContext.loadBeanDefinitions(AbstractXmlApplicationContext.java:80)
at org.springframework.context.support.AbstractRefreshableApplicationContext.refreshBeanFactory(AbstractRefreshableApplicationContext.java:123)
at org.springframework.context.support.AbstractApplicationContext.obtainFreshBeanFactory(AbstractApplicationContext.java:423)
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:353)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:93)
at org.apache.camel.spring.Main.createDefaultApplicationContext(Main.java:189)
at org.apache.camel.spring.Main.doStart(Main.java:152)
at org.apache.camel.impl.ServiceSupport.start(ServiceSupport.java:47)
at org.apache.camel.util.MainSupport.run(MainSupport.java:121)
at org.apache.camel.util.MainSupport.run(MainSupport.java:310)
at org.apache.camel.spring.Main.main(Main.java:72)
++++++
해결책
그래서 그것은 Maven 아래에서 잘 작동하지만 어떻게 실행해도하지 않습니까? 당신의 IDE 또는 뭔가?
Eclipse / Intellij를 사용하는 경우 Maven을 사용하여 Maven 프로젝트를위한 IDE 프로젝트를 만들 수 있습니다.
mvn eclipse:eclipse
또는
mvn idea:idea
쉘 스크립트를 작성하거나 명령 줄에서 실행하는 경우 항아리가 없을 가능성이 높습니다. Spring + Jaxb + Commons-Logging + Camel-Core, Camel-Spring 및 Camel-JMS가 필요합니다.
Maven 유형의 정확한 종속성 목록을 얻으려면
mvn dependency:tree
다른 팁
이 특별한 예외는 Camel-JMS Library .jar가 ClassPath에 있지 않을 때 발생합니다. 제임스가 언급했듯이,이 라이브러리가 실행할 때 클래스 경로에 올바르게 있는지 확인하십시오.
낙타를 사용할 때 비슷한 문제가있었습니다 (낙타 1.3이지만). 제 경우에는 오류가 다음과 같습니다.
org.springframework.beans.factory.parsing.BeanDefinitionParsingException: Configuration problem: Unable to locate NamespaceHandler for namespace [http://activemq.apache.org/camel/schema/spring]
JDK 버전을 변경하여 고칠 수있었습니다. JDK 1.5를 사용하고 있었고 1.6으로 업그레이드하여 문제를 해결했습니다. 도움이 되었기를 바랍니다.
모니카
어떤 버전의 JDK1.5를 사용하고 있습니까? Eclipse 대 명령 줄에서 다른 JDK를 사용하고 있습니까?
JAXB에 올바른 버전이없는 문제가 될 수 있습니다. JAXB 2.1 이상이어야합니다.
Eclipse와 외부 도구 (Maven)와 같은 문제가있었습니다. James와 Pete가 지적한 것처럼 Camel-JMs.jar를 클래스 경로 안에 추가하여 내 문제를 해결했습니다. Camel-Core와 Camel-JMS가 기본적인 필수 의존성 인 것 같습니다.
<dependency>
<groupId>org.apache.camel</groupId>
<artifactId>camel-core</artifactId>
<version>1.6.0</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>org.apache.camel</groupId>
<artifactId>camel-jms</artifactId>
<version>1.6.0</version>
<scope>runtime</scope>
</dependency>