如何减少 Google App Engine 数据存储延迟?
通过appstats,我可以看到我的数据存储查询大约需要125毫秒(api和cpu组合),但在执行查询之前通常存在很长的延迟(例如,长达12000毫秒)。
我可以看到我来自数据存储的延迟与我的查询无关(例如,相同的查询/数据具有截然不同的延迟),因此我假设这是应用程序引擎的调度问题。
其他人是否看到同样的问题?
有没有办法减少延迟(例如管理控制台设置)?
这是来自appstats的屏幕截图。此 servlet 具有很少的 CPU 处理。它执行 getObjectByID,然后执行数据存储查询。该查询具有 OR 运算符,因此应用引擎将其转换为 3 个查询。
.如您所见,在执行第一个 getObjectByID 之前需要 6000 毫秒。在获取操作之前没有处理(获取 pm 除外)。我认为这 6000 毫秒的延迟可能是由于实例预热造成的,因此我将空闲实例增加到 2 以防止任何预热。
然后,在 getObjectByID 和查询之间大约 1000 毫秒有第二个延迟。获取和查询之间有零行代码。该代码仅采用 getObjectByID 的结果,并将数据用作查询的一部分。
总计为 8097 毫秒,但我的数据存储操作(以及 99.99% 的 servlet)仅为 514 毫秒(45 毫秒 api),尽管每次运行 servlet 时这些数字都会发生变化。这是另一个 appstats 屏幕截图,它针对相同的数据在同一 servlet 上运行。
这是我的java代码的基础知识。出于安全目的,我不得不删除一些细节。
user = pm.getObjectById(User.class, userKey);
//build queryBuilder.append(...
final Query query = pm.newQuery(UserAccount.class,queryBuilder.toString());
query.setOrdering("rating descending");
query.executeWithArray(args);
编辑:使用Pingdom,我可以看到GAE延迟从450ms到7,399ms不等,或1,644%的差异!这是有两个空闲实例,站点上没有用户。