Java 创建JPA生产者终结点时出错

Java 创建JPA生产者终结点时出错,java,jpa,apache-camel,Java,Jpa,Apache Camel,我不熟悉骆驼。我正在为下面的场景编写一条骆驼路线 从某个位置拾取XML文件 根据XSD验证XML文件 将XML数据持久化到数据库中 我是这样写的 public void configure() throws Exception { JaxbDataFormat jaxb = new JaxbDataFormat(); JAXBContext ctx = JAXBContext.newInstance(Book.class); ja

我不熟悉骆驼。我正在为下面的场景编写一条骆驼路线

  • 从某个位置拾取XML文件
  • 根据XSD验证XML文件
  • 将XML数据持久化到数据库中
  • 我是这样写的

    public void configure() throws Exception {
               JaxbDataFormat jaxb = new JaxbDataFormat();
               JAXBContext ctx = JAXBContext.newInstance(Book.class);
               jaxb.setContext(ctx);
    
               from("file:data/source?noop=true").to("validator:books.xsd")
                                             .to("file:data/destination").split()
                                             .tokenizeXML("book").unmarshal(jaxb)
                                             .to("jpa:com.labs.Book");
    }
    
    我的XML文件是:

    <book>
               <author>Kishore</author>
               <title>The Second Book</title>
               <genre>Fiction</genre>
    </book>
    
    
    基肖尔
    第二本书
    小说
    
    我的XSD是:

    <xs:schema attributeFormDefault="unqualified" elementFormDefault="qualified" xmlns:xs="http://www.w3.org/2001/XMLSchema">
      <xs:element name="book">
        <xs:complexType>
          <xs:sequence>
            <xs:element type="xs:string" name="author" nillable="false"/>
            <xs:element type="xs:string" name="title" nillable="false"/>
            <xs:element type="xs:string" name="genre" nillable="false" fixed="{Fiction,Bio}"/>
          </xs:sequence>
        </xs:complexType>
      </xs:element>
    </xs:schema>
    
    
    
    我有XML的JAXB模型。我还有pesristence.xml文件。但当我试图执行我的应用程序时,我得到了一个如下所示的异常

    SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
    SLF4J: Defaulting to no-operation (NOP) logger implementation
    SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
    log4j:WARN No appenders could be found for logger (org.springframework.orm.jpa.LocalEntityManagerFactoryBean).
    log4j:WARN Please initialize the log4j system properly.
    log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
    1168  camel  WARN   [main] openjpa.Enhance - Unenhanced classes were detected even though the enhancer has ran. Ensure that the EntityManagerFactory is created prior to creating any Entities.    
    Exception in thread "main" org.apache.camel.FailedToCreateProducerException: Failed to create Producer for endpoint: Endpoint[jpa://com.labs.Book]. Reason: <openjpa-2.3.0-r422266:1540826 nonfatal user error> org.apache.openjpa.persistence.ArgumentException: This configuration disallows runtime optimization, but the following listed types were not enhanced at build time or at class load time with a javaagent: "
    com.labs.Book".
               at org.apache.camel.impl.ProducerCache.doGetProducer(ProducerCache.java:409)
               at org.apache.camel.impl.ProducerCache.acquireProducer(ProducerCache.java:123)
               at org.apache.camel.processor.SendProcessor.doStart(SendProcessor.java:202)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.DelegateAsyncProcessor.doStart(DelegateAsyncProcessor.java:79)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.RedeliveryErrorHandler.doStart(RedeliveryErrorHandler.java:1154)
               at org.apache.camel.support.ChildServiceSupport.start(ChildServiceSupport.java:41)
               at org.apache.camel.support.ChildServiceSupport.start(ChildServiceSupport.java:28)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.interceptor.DefaultChannel.doStart(DefaultChannel.java:153)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:61)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.MulticastProcessor.doStart(MulticastProcessor.java:993)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:61)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.MulticastProcessor.doStart(MulticastProcessor.java:993)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
              at org.apache.camel.processor.DelegateAsyncProcessor.doStart(DelegateAsyncProcessor.java:79)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.RedeliveryErrorHandler.doStart(RedeliveryErrorHandler.java:1154)
               at org.apache.camel.support.ChildServiceSupport.start(ChildServiceSupport.java:41)
               at org.apache.camel.support.ChildServiceSupport.start(ChildServiceSupport.java:28)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.interceptor.DefaultChannel.doStart(DefaultChannel.java:153)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:61)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.MulticastProcessor.doStart(MulticastProcessor.java:993)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
               at org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
               at org.apache.camel.processor.DelegateAsyncProcessor.doStart(DelegateAsyncProcessor.java:79)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
               at org.apache.camel.impl.RouteService.startChildService(RouteService.java:334)
               at org.apache.camel.impl.RouteService.warmUp(RouteService.java:158)
               at org.apache.camel.impl.DefaultCamelContext.doWarmUpRoutes(DefaultCamelContext.java:2263)
               at org.apache.camel.impl.DefaultCamelContext.safelyStartRouteServices(DefaultCamelContext.java:2193)
               at org.apache.camel.impl.DefaultCamelContext.doStartOrResumeRoutes(DefaultCamelContext.java:1981)
               at org.apache.camel.impl.DefaultCamelContext.doStartCamel(DefaultCamelContext.java:1851)
               at org.apache.camel.impl.DefaultCamelContext.doStart(DefaultCamelContext.java:1683)
               at org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
               at org.apache.camel.impl.DefaultCamelContext.start(DefaultCamelContext.java:1651)
               at com.labs.App.main(App.java:36)
    Caused by: <openjpa-2.3.0-r422266:1540826 nonfatal user error> org.apache.openjpa.persistence.ArgumentException: This configuration disallows runtime optimization, but the following listed types were not enhanced at build time or at class load time with a javaagent: "
    com.labs.Book".
               at org.apache.openjpa.enhance.ManagedClassSubclasser.prepareUnenhancedClasses(ManagedClassSubclasser.java:115)
               at org.apache.openjpa.kernel.AbstractBrokerFactory.loadPersistentTypes(AbstractBrokerFactory.java:312)
               at org.apache.openjpa.kernel.AbstractBrokerFactory.initializeBroker(AbstractBrokerFactory.java:236)
               at org.apache.openjpa.kernel.AbstractBrokerFactory.newBroker(AbstractBrokerFactory.java:212)
               at org.apache.openjpa.kernel.DelegatingBrokerFactory.newBroker(DelegatingBrokerFactory.java:155)
               at org.apache.openjpa.persistence.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:226)
               at org.apache.openjpa.persistence.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:153)
               at org.apache.openjpa.persistence.EntityManagerFactoryImpl.createEntityManager(EntityManagerFactoryImpl.java:59)
               at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
               at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
               at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
               at java.lang.reflect.Method.invoke(Method.java:606)
               at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean.invokeProxyMethod(AbstractEntityManagerFactoryBean.java:376)
               at org.springframework.orm.jpa.AbstractEntityManagerFactoryBean$ManagedEntityManagerFactoryInvocationHandler.invoke(AbstractEntityManagerFactoryBean.java:519)
               at com.sun.proxy.$Proxy20.createEntityManager(Unknown Source)
               at org.apache.camel.component.jpa.JpaEndpoint.createEntityManager(JpaEndpoint.java:284)
               at org.apache.camel.component.jpa.JpaProducer.<init>(JpaProducer.java:44)
               at org.apache.camel.component.jpa.JpaEndpoint.createProducer(JpaEndpoint.java:106)
               at org.apache.camel.impl.ProducerCache.doGetProducer(ProducerCache.java:405)
               ... 82 more
    
    SLF4J:未能加载类“org.SLF4J.impl.StaticLoggerBinder”。
    SLF4J:默认为无操作(NOP)记录器实现
    SLF4J:参见http://www.slf4j.org/codes.html#StaticLoggerBinder 详情请参阅。
    log4j:WARN找不到记录器(org.springframework.orm.jpa.LocalEntityManagerFactoryBean)的附加程序。
    log4j:警告请正确初始化log4j系统。
    log4j:请参阅http://logging.apache.org/log4j/1.2/faq.html#noconfig 更多信息。
    1168 camel WARN[main]openjpa.Enhance-即使增强器已运行,也检测到未增强的类。确保在创建任何实体之前创建EntityManagerFactory。
    线程“main”org.apache.camel.FailedToCreateProducerException中出现异常:未能为端点创建生产者:端点[jpa://com.labs.Book]. 原因:org.apache.openjpa.persistence.ArgumentException:此配置不允许运行时优化,但以下列出的类型在生成时或类加载时未使用javaagent进行增强:
    com.labs.Book”。
    位于org.apache.camel.impl.ProducerCache.doGetProducer(ProducerCache.java:409)
    位于org.apache.camel.impl.ProducerCache.acquireProducer(ProducerCache.java:123)
    位于org.apache.camel.processor.SendProcessor.doStart(SendProcessor.java:202)
    位于org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
    位于org.apache.camel.processor.DelegateAsyncProcessor.doStart(DelegateAsyncProcessor.java:79)
    位于org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
    位于org.apache.camel.processor.RedeliveryRorHandler.doStart(RedeliveryRorHandler.java:1154)
    位于org.apache.camel.support.ChildServiceSupport.start(ChildServiceSupport.java:41)
    位于org.apache.camel.support.ChildServiceSupport.start(ChildServiceSupport.java:28)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
    位于org.apache.camel.processor.interceptor.DefaultChannel.doStart(DefaultChannel.java:153)
    位于org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:61)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
    位于org.apache.camel.processor.MulticastProcessor.doStart(MulticastProcessor.java:993)
    位于org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:61)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
    位于org.apache.camel.processor.MulticastProcessor.doStart(MulticastProcessor.java:993)
    位于org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:89)
    位于org.apache.camel.processor.DelegateAsyncProcessor.doStart(DelegateAsyncProcessor.java:79)
    位于org.apache.camel.support.ServiceSupport.start(ServiceSupport.java:61)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:74)
    位于org.apache.camel.util.ServiceHelper.startService(ServiceHelper.java:59)
    位于org.apache.camel.util.ServiceHelper.startServices(ServiceHelper.java:103)
    位于org.apache.camel.util.ServiceHelper.startServ