java - App Engine 前端到数据库的延迟每约 20 次调用暂时约 10 秒?

标签 java google-app-engine

这种情况(见下图)是从 3/7 开始发生的。 当然,这可能是由于实例加载和卸载造成的。 但您知道 GAE 出现这种行为的其他原因吗?

这不是一个高复制实例。在测试过程中,我们最多有 5 个 F2 实例在运行,仅用于我们的测试客户端调用。基本上有DB调用、图像处理和memcache使用。

已经有 2 个看起来相同的问题: http://code.google.com/p/googleappengine/issues/detail?id=4180&sort=priority&colspec=ID%20Type%20Component%20Status%20Stars%20Summary%20Language%20Priority%20Owner%20Log

http://code.google.com/p/googleappengine/issues/detail?id=6309&sort=priority&colspec=ID%20Type%20Component%20Status%20Stars%20Summary%20Language%20Priority%20Owner%20Log

论坛中有一个条目: https://groups.google.com/forum/#!topic/google-appengine/js5CeRWLQZ0/discussion

GAE-J Appstat Chart

日志记录(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/

相关文章:

java - 在 Intellij 中,当我在本地运行 Google App Engine 时,为什么必须清理和构建 war 才能看到变化?

java - LWJGL Circle 程序创建椭圆形形状

java - 在 Spring Boot 应用程序上添加动态属性

java - 无法在我的 Galaxy 手机上部署简单的 Android 应用程序

google-app-engine - dev/urandom-strerror : file not accessible

google-app-engine - angularjs html5mode刷新页面获取404

java - 将 super/this 构造函数调用中抛出的异常包装到其他异常中

java - ORA-01747 : invalid user. table.column、table.column 或 java 中的列规范

java - 如何使用 java 创建通用且可重用的代码

python - 从 .txt 文件加载页面内容会破坏 Django 模板系统