Ошибка Datanucleus Enhancer = 7 после компиляции GWT - PullRequest
0 голосов
/ 19 сентября 2018

Я создаю проект GWT + App Engine + JDO с Maven и Eclipse Photon (та же ошибка, когда я строю проект из командной строки).После фазы компиляции Datanucleus уведомляет меня об ошибке:

Failed to execute goal org.datanucleus:maven-datanucleus-plugin:3.2.0-m1:enhance (default) on project gwtAppEngineJDOProjectName: Error while executing the DataNucleus tool 'org.datanucleus.enhancer.DataNucleusEnhancer'. Error while executing process. Cannot run program "/bin/sh": error=7

В структуре моего проекта есть META-INF/jdoconfig.xml при src/main/resources.После запуска плагина war META-INF/jdoconfig.xml были правильно сохранены в папке / target / WARFOLDER / MET-INF /.

Мой фактический jdo-conf:

  <?xml version="1.0" encoding="utf-8" standalone="no"?>
<jdoconfig xmlns="http://java.sun.com/xml/ns/jdo/jdoconfig" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
xsi:schemaLocation="http://java.sun.com/xml/ns/jdo/jdoconfig http://java.sun.com/xml/ns/jdo/jdoconfig_3_0.xsd">
  <persistence-manager-factory name="transactions-optional">
      <property name="javax.jdo.PersistenceManagerFactoryClass" value="org.datanucleus.api.jdo.JDOPersistenceManagerFactory"/>
      <property name="javax.jdo.option.ConnectionURL" value="appengine"/>
      <property name="datanucleus.cache.level2.mode" value="none"/>
      <property name="javax.jdo.option.NontransactionalRead" value="true"/>
      <property name="javax.jdo.option.NontransactionalWrite" value="true"/>
      <property name="javax.jdo.option.RetainValues" value="true"/>
      <property name="datanucleus.appengine.autoCreateDatastoreTxns" value="true"/>
      <property name="datanucleus.appengine.singletonPMFForName" value="true"/>
  </persistence-manager-factory>
</jdoconfig>

Процесс автоматического улучшения в моем pom.xml

 <plugin>
    <groupId>org.datanucleus</groupId>
    <artifactId>maven-datanucleus-plugin</artifactId>
    <version>3.2.0-m1</version>
    <configuration>
        <api>JDO</api>
        <props>${basedir}/datanucleus.properties</props>
        <verbose>true</verbose>
        <enhancerName>ASM</enhancerName>
    </configuration>
    <executions>
        <execution>
            <phase>process-classes</phase>
            <goals>
                <goal>enhance</goal>
            </goals>
        </execution>
    </executions>
    <dependencies>
        <dependency>
            <groupId>org.datanucleus</groupId>
            <artifactId>datanucleus-core</artifactId>
            <version>3.1.3</version>
        </dependency>
    </dependencies>
</plugin>

Как я могу решить ошибку = 7 Ошибка Datanucleus?Благодарю.

1 Ответ

0 голосов
/ 19 сентября 2018

Использование datanucleus-maven-plugin с этой конфигурацией:

 <plugin>
        <groupId>org.datanucleus</groupId>
        <artifactId>datanucleus-maven-plugin</artifactId>
        <version>5.0.2</version>
        <configuration>
            <fork>false</fork>
            <log4jConfiguration>${basedir}/log4j.properties</log4jConfiguration>
            <verbose>true</verbose>
        </configuration>
        <executions>
            <execution>
                <phase>process-classes</phase>
                <goals>
                    <goal>enhance</goal>
                </goals>
            </execution>
        </executions>
    </plugin>

Процесс расширения запускается автоматически после фазы компиляции.Параметру fork присвоено значение false, предотвращающее сообщение «список аргументов слишком длинный».См http://www.datanucleus.org/products/accessplatform/jdo/enhancer.html#maven.

...