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