5

我是 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 没有创建。例如,如果我尝试搜索我的持久实体,则会出现错误。

[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

4 回答 4

4

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

appengine {
    jvmFlags=['-Ddatastore.backing_store=../../../local_db.bin']
}
于 2015-06-30T08:57:04.080 回答
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 中,每次构建都会被清除,但您至少可以获得要使用的数据库。希望我(或这里的其他人)能找到更好的方法来让它工作。

于 2013-12-30T17:00:32.787 回答
0

试试这个(对我有用):运行您的代码,以便创建 local_db.bin 文件。然后,当网络服务器仍在运行时,手动将 local_db.bin 文件添加到您的/war/WEB-INF/appengine-generated/ 目录到 eclipse 项目中。

于 2014-06-09T21:15:55.130 回答
0

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

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

所以,我需要告诉 GAE 应用服务器将文件存储在其他地方,这显然不能用 maven 插件生成的应用服务器来做。

解决方案

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

  3. 用这个命令启动你的开发服务器(显然用你自己的交换路径):

    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
    
于 2016-07-28T22:43:55.377 回答