2

我在 appengine 上创建了一个应用程序,但遇到了问题。在我看来,PersistenceManagerFactory 正在为每个请求创建一个到数据存储的新连接。我的数据存储读取通常需要 4 到 5 秒才能读取大约 10 个对象!(它是一个获取所有实体级别的查询)。

在查看 appstats 之后,看起来请求在调用数据存储之前已经在那里停留了大约 3 秒。实际的数据存储时间很小,4-10ms。

然后,我将获取所有查询更改为使用低级别的 DatastoreService api。我创建了一次服务,并在 get all 方法中使用它。这几乎消除了等待时间(除了第一次调用该方法)。所以我猜测 PMF 每次读取都会获得与数据存储的新连接!这似乎很疯狂。

有谁知道如何最小化 PersistenceManager 实例的启动时间?
jdoconfig.xml

   <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="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>

getAll 方法(使用 jdo)

    @Override
    public ArrayList<CrudObject> getAll(String className) {
        List results = null;
        PersistenceManager pm = pmf.getPersistenceManager();
        try{
            Query q = pm.newQuery(Class.forName(className));
            results = (List)q.execute();
            return new ArrayList<CrudObject>(pm.detachCopyAll(results));
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }finally
        {
            pm.close();
        }
        return null;
      }
4

1 回答 1

1

该问题是由于 AppEngine Datastore 平台上的延迟问题造成的。这个问题是暂时的,并且已经修复。这个问题恰好与我第一次使用 JDO 部署到 AppEngine 相吻合,所以我认为这是我的代码。我今天重新测试,它运行得更快。

于 2013-02-04T16:06:59.683 回答