App Engine不会创建local_db.bin

时间:2013-11-07 20:54:17

标签: java maven google-app-engine 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.

我的问题是没有创建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)

...

这是我的实体类:

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;
    }
}

这是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>

此外,如果使用appengine eclipse插件创建此项目,则不会发生任何事情,并且我的代码工作正常。

提前致谢

4 个答案:

答案 0 :(得分:4)

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

appengine {
    jvmFlags=['-Ddatastore.backing_store=../../../local_db.bin']
}

答案 1 :(得分:2)

我一直在使用App Engine,但最近转换了一个项目以使用Maven和Maven插件。我有一个非常类似的问题 - 似乎创建local_db.bin文件不是启动操作的一部分。

但是,当我尝试从数据存储区读取时,一条日志消息表明由于未找到local_db.bin,因此将创建一个(抱歉,我没有准确的日志消息)。之后我能够正常使用该应用程序,确实创建了local_db。

但是,我注意到它是在target目录中创建local_db.bin文件,而不是在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中,每次构建都会被删除,但您至少可以获得一个数据库使用。希望我(或其他人)可以找到更好的方法来实现这一点。

答案 2 :(得分:0)

试试这个(为我工作):运行你的代码,以便创建local_db.bin文件。然后,当web服务器仍在运行时,将local_db.bin文件添加到/ war / WEB-INF / appengine-generated /目录到eclipse项目。

答案 3 :(得分:0)

我几个月来一直在努力解决这个问题,最终找到了合理的解决方案。

对我来说,问题是服务器想要将local_db.bin保存在我的/ target目录中 - 这是我的开发环境中最易变和经常删除的目录。每个构建都意味着一个WIPED OUT数据库。

所以,我需要告诉GAE应用服务器将文件存储在其他地方,你显然无法使用maven插件生成的appserver。

<强>解

  1. 不要使用maven插件(appengine-maven-plugin)来启动一个devserver。有了它,您无法更改local_db.bin的位置。而是从here下载本地开发服务器。 / bin目录将包含您需要的dev_appserver.sh。
  2. 创建一个可以包含数据库的文件夹,例如/ Users / Myself / path / to / sdk / APPENGINE_DB

  3. 使用此命令启动您的dev服务器(显然用您自己的路径交换路径):

    cd /Users/Myself/path/to/sdk/appengine-java-sdk-1.9.40/bin
    sh dev_appserver.sh --generated_dir=/Users/Myself/path/to/sdk/APPENGINE_DB /Users/Myself/Projects/myapp/target/mayapp-1.0