App Engine不会创建local_db.bin

dav*_*ron 5 java google-app-engine maven jpa-2.0

我是appengine的新手,我使用的是appengine版本1.8.7(在1.8.6中也适用于我),并尝试将maven添加到项目中.

当我持久化实体时,日志如下:

[INFO] nov 07, 2013 5:38:33 PM com.google.appengine.api.datastore.dev.LocalDatastoreService init
[INFO] INFO: Local Datastore initialized:
[INFO]  Type: High Replication
[INFO]  Storage: D:\Projects\JEE\myapp\tmp\local_db.bin
[INFO] nov 07, 2013 5:38:33 PM com.google.appengine.api.datastore.dev.LocalDatastoreService load
[INFO] INFO: The backing store, D:\Projects\JEE\myapp\tmp\local_db.bin, does not exist. It will be created.
Run Code Online (Sandbox Code Playgroud)

我的问题是没有创建local_db.bin.例如,如果我尝试搜索我的peristed实体,则会出现错误.

[INFO] java.lang.IllegalArgumentException: Type com.harriague.myapp.dao.entities.Travel is not a known entity type
[INFO]  at org.datanucleus.api.jpa.metamodel.MetamodelImpl.entity(MetamodelImpl.java:193)
Run Code Online (Sandbox Code Playgroud)

...

这是我的实体类:

package com.harriague.myapp.dao.entities;

import javax.persistence.Entity;
import javax.persistence.GeneratedValue;
import javax.persistence.GenerationType;
import javax.persistence.Id;
import javax.persistence.Column;

import com.google.appengine.api.datastore.Key;

@Entity(name = "Travel")
public class Travel {

    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Key travelId;

    @Column(name = "name")
    private String name;

    public Travel() {

    }

    public Key getTravelId() {
        return travelId;
    }

    public void setTravelId(Key travelId) {
        this.travelId = travelId;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}
Run Code Online (Sandbox Code Playgroud)

这是mi pom.xml:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

    <modelVersion>4.0.0</modelVersion>
    <packaging>war</packaging>
    <version>1.0-SNAPSHOT</version>

    <groupId>com.harriague</groupId>
    <artifactId>myapp</artifactId>


    <properties>
        <appengine.app.version>1</appengine.app.version>
        <appengine.target.version>1.8.7</appengine.target.version>
        <datanucleus-core.version>3.1.3</datanucleus-core.version>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <!-- Compile/runtime dependencies -->
        <dependency>
            <groupId>com.google.appengine</groupId>
            <artifactId>appengine-api-1.0-sdk</artifactId>
            <version>${appengine.target.version}</version>
        </dependency>
        <dependency>
            <groupId>com.google.appengine</groupId>
            <artifactId>appengine-endpoints</artifactId>
            <version>${appengine.target.version}</version>
        </dependency>
        <dependency>
            <groupId>com.google.appengine</groupId>
            <artifactId>appengine-api-labs</artifactId>
            <version>${appengine.target.version}</version>
        </dependency>
        <dependency>
            <groupId>org.ow2.asm</groupId>
            <artifactId>asm</artifactId>
            <version>4.0</version>
        </dependency>

        <dependency>
            <groupId>javax.servlet</groupId>
            <artifactId>servlet-api</artifactId>
            <version>2.5</version>
            <scope>provided</scope>
        </dependency>
        <dependency>
            <groupId>jstl</groupId>
            <artifactId>jstl</artifactId>
            <version>1.2</version>
        </dependency>

        <!-- JSON -->
        <dependency>
            <groupId>com.googlecode.json-simple</groupId>
            <artifactId>json-simple</artifactId>
            <version>1.1.1</version>
        </dependency>

        <!-- Test Dependencies -->
        <dependency>
            <groupId>com.google.appengine</groupId>
            <artifactId>appengine-testing</artifactId>
            <version>${appengine.target.version}</version>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>com.google.appengine</groupId>
            <artifactId>appengine-api-stubs</artifactId>
            <version>${appengine.target.version}</version>
            <scope>test</scope>
        </dependency>

        <!-- Spring framework -->
        <!-- 
        <dependency>
            <groupId>org.springframework</groupId>
            <artifactId>spring</artifactId>
            <version>2.5.6</version>
        </dependency>
        -->

        <!-- Javax persistence -->
        <dependency>
            <groupId>org.datanucleus</groupId>
            <artifactId>datanucleus-core</artifactId>
            <version>${datanucleus-core.version}</version>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.apache.geronimo.specs</groupId>
            <artifactId>geronimo-jpa_2.0_spec</artifactId>
            <version>1.1</version>
        </dependency>
        <dependency>
            <groupId>org.datanucleus</groupId>
            <artifactId>datanucleus-api-jpa</artifactId>
            <version>3.1.3</version>
        </dependency>
        <dependency>
            <groupId>com.google.appengine.orm</groupId>
            <artifactId>datanucleus-appengine</artifactId>
            <version>2.1.2</version>
            <!-- Need to exclude the enhancer since it interfere with the enhancer plugin. -->
            <exclusions>
              <exclusion>
                <groupId>org.datanucleus</groupId>
                <artifactId>datanucleus-enhancer</artifactId>
              </exclusion>
            </exclusions>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <version>2.5.1</version>
                <artifactId>maven-compiler-plugin</artifactId>
                <configuration>
                    <source>1.6</source>
                    <target>1.6</target>
                </configuration>
            </plugin>

            <plugin>
                <groupId>org.apache.maven.plugins</groupId>
                <artifactId>maven-war-plugin</artifactId>
                <version>2.3</version>
                <configuration>
                    <archiveClasses>true</archiveClasses>
                    <webResources>
                        <!-- in order to interpolate version from pom into appengine-web.xml -->
                        <resource>
                            <directory>${basedir}/src/main/webapp/WEB-INF</directory>
                            <filtering>true</filtering>
                            <targetPath>WEB-INF</targetPath>
                        </resource>
                        <!--
                        <resource>
                            <directory>${basedir}/src/main/resources</directory>
                        </resource>
                        -->
                    </webResources>
                </configuration>
            </plugin>

            <plugin>
                <groupId>com.google.appengine</groupId>
                <artifactId>appengine-maven-plugin</artifactId>
                <version>${appengine.target.version}</version>
                <configuration>
                    <enableJarClasses>false</enableJarClasses>
                    <!--<jvmFlags>
                        <jvmFlag>-Ddatastore.backing_store=${basedir}\local_db.bin</jvmFlag>
                    </jvmFlags>
                    -->
                    <jvmFlags>
                        <jvmFlag>-Dappengine.generated.dir=${basedir}/tmp</jvmFlag>
                    </jvmFlags>
                    <!--
                    <jvmFlags>
                        <jvmFlag>-Xdebug</jvmFlag>
                        <jvmFlag>-Xrunjdwp:transport=dt_socket,address=8080,server=y,suspend=y</jvmFlag>
                    </jvmFlags>
                    -->
                    <disableUpdateCheck>true</disableUpdateCheck>
                </configuration>
            </plugin>

            <plugin>
                <groupId>org.datanucleus</groupId>
                <artifactId>maven-datanucleus-plugin</artifactId>
                <version>3.1.1</version>
                <configuration>
                    <api>JPA</api>
                    <fork>false</fork>
                    <persistenceUnitName>transactions-optional</persistenceUnitName>
                    <verbose>true</verbose>
                </configuration>
                <executions>
                    <execution>
                        <phase>process-classes</phase>
                        <goals>
                            <goal>enhance</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>
Run Code Online (Sandbox Code Playgroud)

另外,如果这个项目是用appengine eclipse插件创建的,那么这一切都没有发生,我的代码工作得很好.

提前致谢

Bao*_* Le 5

在 Android Studio 或 Gradle 构建系统中,您可以使用 jvmFlags 覆盖默认路径。将以下代码添加到 build.gradle

appengine {
    jvmFlags=['-Ddatastore.backing_store=../../../local_db.bin']
}
Run Code Online (Sandbox Code Playgroud)


小智 2

我已经使用 App Engine 一段时间了,但最近将一个项目转换为使用 Maven 和 Maven 插件。我遇到了一个非常类似的问题 - 创建 local_db.bin 文件似乎不是启动操作的一部分。

但是,当我尝试从数据存储中读取时,一条日志消息表明,由于未找到 local_db.bin,因此将创建该文件(抱歉,我手边没有确切的日志消息)。之后我就可以正常使用该应用程序了,local_db确实被创建了。

但是,我注意到它是在目录中创建 local_db.bin 文件target,而不是在src目录中,因此每次重新启动服务器时,local_db.bin 文件都会被清除,必须重新创建。因此,一旦local_db.bin创建,您就可以在 中找到它target/your_SNAPSHOT/WEB-INF/appengine-generated并将其复制到您的src/main/webapp/WEB-INF/appengine-generated目录中。target当您进行构建时,它应该包含在您的目录中。

请注意,这有一些缺点 - 您在将来的会话中所做的任何数据更改都不会持久,因为它们存储在 local_db.bin 中,每次构建都会被清除,但您至少可以获取可供使用的数据基础。希望我(或这里的其他人)能够找到更好的方法来让它发挥作用。