这种情况(见下图)是从 3/7 开始发生的。 当然,这可能是由于实例加载和卸载造成的。 但您知道 GAE 出现这种行为的其他原因吗?
这不是一个高复制实例。在测试过程中,我们最多有 5 个 F2 实例在运行,仅用于我们的测试客户端调用。基本上有DB调用、图像处理和memcache使用。
论坛中有一个条目: https://groups.google.com/forum/#!topic/google-appengine/js5CeRWLQZ0/discussion
日志记录(Shay 请求)显示持久性管理器似乎需要 6 秒来初始化:
2012-03-11 15:32:47.543 /api/yyy 200 16811ms 0kb xxx/1.1 CFNetwork/548.1.4 Darwin/11.0.0
78.53.230.114 - - [11/Mar/2012:07:32:47 -0700] "POST /api/yyy HTTP/1.1" 200 94 - "zzz/1.1 CFNetwork/548.1.4 Darwin/11.0.0" "zzz.appspot.com" ms=16812 cpu_ms=6040 api_cpu_ms=82 cpm_usd=0.167820 pending_ms=5765 instance=00c71b117ca3858c47bdc41d5b30a732dd76eaaf
I 2012-03-11 15:32:37.196
www.server.xxxServlet getvvv: 1
I 2012-03-11 15:32:37.202
www.server.xxxServlet getvvv: hash
I 2012-03-11 15:32:37.207
www.server.xxxServlet getvvv: get PM (PersistenceManager pm = PMF.get().getPersistenceManager();)
I 2012-03-11 15:32:43.606
www.server.xxxServlet getvvv: get data
I 2012-03-11 15:32:47.355
www.server.xxxServlet getvvv: got data
I 2012-03-11 15:32:47.388
www.server.xxxServlet getvvv: done
PMF 的实现如下:
public final class PMF {
private static final PersistenceManagerFactory pmfInstance =
JDOHelper.getPersistenceManagerFactory("transactions-optional");
private PMF() {}
public static PersistenceManagerFactory get() {
return pmfInstance;
}
}
最佳答案
您看不到任何统计信息的区域通常是您的代码正在运行,统计信息在输入请求时开始,我认为这与实例加载没有任何关系。
我建议添加日志以查看处理程序代码的流程。
关于java - App Engine 前端到数据库的延迟每约 20 次调用暂时约 10 秒?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9638648/