繁体   English   中英

连接到Google App Engine数据存储区

[英]Connect to Google App Engine Datastore

我正在尝试从Java本地计算机连接到Google App Engine的数据存储区。 我不会将该服务与GAE上的应用程序一起使用,它将在AWS上使用。

我尝试了什么

我尝试使用DatastoreService datastore = DatastoreServiceFactory.getDatastoreService(); ,但我认为应用程序是在GAE上托管的。

现在,我使用系统变量GOOGLE_APPLICATION_CREDENTIALS获取的json凭证文件启动并运行Google存储。 连接工作正常,所以我的猜测是我可能需要做类似于存储的事情。 我为Storage做了类似的事情:

HttpTransport transport = GoogleNetHttpTransport.newTrustedTransport();
        JsonFactory jsonFactory = new JacksonFactory();
        GoogleCredential credential = GoogleCredential.getApplicationDefault(transport, jsonFactory);

        if (credential.createScopedRequired()) {
            Collection<String> bigqueryScopes = StorageScopes.all();
            credential = credential.createScoped(bigqueryScopes);
        }

        Storage client = new Storage.Builder(transport, jsonFactory, credential)
                .setApplicationName("APPLICATION_NAME")
                .build();

这个问题

所以我的问题是:如何从Google App Engine外部连接到Google App Engine数据存储区?

谢谢您的帮助!

我建议你转移到gcloud-java客户端库 它建立在您当前使用的代码之上,并且使得使用数据存储区和存储更容易,尽管文档几乎不存在(截至2016年4月)。

这是使用此库连接到数据存储区的方式:

AuthCredentials credentials = AuthCredentials.createFor(account, key);
DatastoreOptions options = DatastoreOptions.builder()
        .authCredentials(credentials)
        .projectId(projectId)
        .namespace(NAMESPACE)
        .build();
Datastore datastore = options.service();

与存储相同,但使用StorageOptions。

提示:在GitHub中打开gcloud-java项目 - 该链接位于我之前引用的页面上。 有一个文件夹,其中包含如何使用数据存储和存储的示例。

借助Andrei Volgin的大力帮助,我成功地从Google App Engine以外的应用程序连接到Datastore。 这是我在2016年4月所做的事情:

  • 启用Datastore API v1beta3。 App Engine中的默认值为v1beta2。 https://console.cloud.google.com/apis/api/datastore.googleapis.com/overview?project=PROJECT_NAME
  • 获取已激活数据存储的服务的凭据文件。
  • 您可以使用GOOGLE_APPLICATION_CREDENTIALS=/path/to/credentials.json在系统变量中设置凭证文件
  • 我将此代码编写为测试并且连接正常

     DatastoreOptions options = DatastoreOptions.builder() .projectId("PROJECT_NAME") .authCredentials(AuthCredentials.createForJson( new FileInputStream("/PATH/TO/CREDENTIALS.json"))).build(); Datastore datastore = options.service(); Query<Entity> query = Query.gqlQueryBuilder(Query.ResultType.ENTITY, "SELECT * FROM user").build(); QueryResults<Entity> results = datastore.run(query); while (results.hasNext()) { Entity result = results.next(); System.out.println(result.getString("id")); } 

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM