在同一应用程序中使用Google Data Store和Google App Engine

时间:2013-08-10 11:55:45

标签: java google-app-engine jpa google-cloud-datastore google-cloud-sql

我有一个应用程序,我将所有数据存储在Google Cloud SQL中。但现在我认为有些表可以移动到Google数据存储区。所以我的问题是如何使用相同的应用程序同时使用Data Store和Cloud SQL。我尝试检查数据存储和云SQL的选项,但它只存在于Cloud SQL中。

这是我的persistence.xml文件。

<?xml version="1.0" encoding="UTF-8" ?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence"
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="http://java.sun.com/xml/ns/persistence
        http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd"
    version="1.0">

    <persistence-unit name="transactions-optional1">
        <provider>org.datanucleus.api.jpa.PersistenceProviderImpl</provider>
        <class>com.sample.poc.Component</class>
        <properties>
            <property name="datanucleus.NontransactionalRead" value="true"/>
            <property name="datanucleus.NontransactionalWrite" value="true"/>
            <property name="datanucleus.ConnectionURL" value="appengine"/>
            <property name="datanucleus.singletonEMFForName" value="true"/>
        </properties>

    </persistence-unit>


    <persistence-unit name="transactions-optional2"
        transaction-type="RESOURCE_LOCAL">
        <provider> org.datanucleus.jpa.PersistenceProviderImpl</provider>
        <class>com.sample.poc.User</class>
        <class>com.sample.poc.Role</class>

        <properties>
          <property name="javax.persistence.jdbc.driver"
                value="com.google.appengine.api.rdbms.AppEngineDriver" />
            <property name="javax.persistence.jdbc.url"
                value="jdbc:google:rdbms://span-test-app:testinstance/pocDB" />
            <property name="javax.persistence.jdbc.user" value="" />
            <property name="javax.persistence.jdbc.password" value="" />
        </properties>

    </persistence-unit>

</persistence>

这是我的两个EMF bean:

对于数据存储区:

package com.sample.poc;


import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;

public final class EMFDS {
    private static final EntityManagerFactory emfInstance = Persistence
            .createEntityManagerFactory("transactions-optional1");

    private EMFDS() {
    }

    public static EntityManagerFactory get() {
        return emfInstance;
    }
}

这是用于cloud sql的EMF bean:

package com.sample.poc;


import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;

public final class EMFRDBMS {
    private static final EntityManagerFactory emfInstance = Persistence
            .createEntityManagerFactory("transactions-optional");

    private EMFRDBMS() {
    }

    public static EntityManagerFactory get() {
        return emfInstance;
    }
}

这是用于在数据存储区中插入组件的servlet:

package com.sample.poc;

import java.io.IOException;

import javax.persistence.EntityManager;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class ComponentInsert extends HttpServlet {

    private static final long serialVersionUID = 1L;

    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    String CompId = request.getParameter("CompId");  
    String CompName= request.getParameter("CompName");  
    response.setContentType("text/html");  
    EntityManager e = EMFDS.get().createEntityManager();
    try {
        e.getTransaction().begin();
        Component ob = new Component();
        ob.setCompId(Integer.parseInt(CompId));
        ob.setCompName(CompName);
        e.persist(ob);
        e.getTransaction().commit();
    } catch (Exception ex) {
        e.getTransaction().rollback();
        ex.printStackTrace();
    }
}

}

我只想要将用户,角色bean保存在云sql和数据存储区中的组件中。

当我尝试在数据存储区中插入组件时,它会抛出此异常:

Caused by: javax.persistence.PersistenceException: No persistence providers available for "transactions-optional1" after trying the following discovered implementations: org.datanucleus.api.jpa.PersistenceProviderImpl
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:180)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:70)
    at com.sample.poc.EMFDS.<clinit>(EMFDS.java:9)
    ... 40 more
12 Aug, 2013 9:48:24 AM com.google.apphosting.utils.jetty.JettyLogger warn
WARNING: Nested in java.lang.ExceptionInInitializerError:
javax.persistence.PersistenceException: No persistence providers available for "transactions-optional1" after trying the following discovered implementations: org.datanucleus.api.jpa.PersistenceProviderImpl
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:180)
    at javax.persistence.Persistence.createEntityManagerFactory(Persistence.java:70)

我错过了一些东西。请建议。

1 个答案:

答案 0 :(得分:1)

您没有为一个持久性单元指定“提供者” - 您将使用哪个JPA提供程序用于cloud-sql?所以指定它。

另一个持久性单元的“提供者”无效。正如消息所述,GAE JPA v2是“org.datanucleus.api.jpa.PersistenceProviderImpl”,但您似乎想要使用一些(非常旧的,不受支持的)GAE JPA 1变体。确保你在CLASSPATH中有正确的一个(而不是另一个)

CLASSPATH中有哪个“JPA API”jar? (这不是JPA实现)。如果您使用的是GAE JPA v2,则需要JPA API v2(geronimo-jpa_2.0_spec)和NOT JPA API v1(geronimo-jpa_3.0_spec)。如果使用的JPA提供者之一是JPA2,那么另一个也必须是JPA2。