Google Appengine数据存储区超时例外

时间:2016-08-25 08:30:17

标签: java google-app-engine cron google-cloud-datastore

我们从数据存储区获取名称空间列表,最多可达30k。

获取命名空间的cron每天运行。但有一天它工作正常,有一天它会引发数据存储超时异常。

  

com.google.appengine.api.datastore.DatastoreTimeoutException:The   数据存储区操作超时,或者数据是暂时的   不可用。

相关代码:

DatastoreService ds = DatastoreServiceFactory.getDatastoreService();
FetchOptions options = FetchOptions.Builder.withChunkSize(150);
Query q = new Query(Entities.NAMESPACE_METADATA_KIND);

for (Entity e : ds.prepare(q).asIterable(options)){
   // A nonzero numeric id denotes the default namespace;
   // see Namespace Queries, below
   if (e.getKey().getId() != 0){
      continue;
   }else{
      namespaces.add(e.getKey().getName());
   }
}

可能是什么问题?

1 个答案:

答案 0 :(得分:1)

根据官方文件:

  

数据存储区操作次数时抛出DatastoreTimeoutException   出。当您尝试放置,获取或删除太多时,可能会发生这种情况   实体或具有太多属性的实体,或者数据存储区   超载或遇到麻烦。

这意味着数据存储区会因您的请求而出现问题。尝试处理该错误,如:

import com.google.appengine.api.datastore.DatastoreTimeoutException;    
    try {
      // Code that could result in a timeout
    } catch (DatastoreTimeoutException e) {
      // Display a timeout-specific error page
    }