通过Cloud Datastore API连接到开发中的AppEngine数据存储区

时间:2014-02-18 20:45:59

标签: google-app-engine go google-cloud-datastore

我们目前正在运行一个组合的AppEngine / GCE应用程序,到目前为止,我们已经在AppEngine方面保留了所有数据存储区访问权限。现在我们正在探索允许我们的GCE实例对(共享)数据存储区进行一些查询。首先,我想弄清楚如何在本地运行。到目前为止我们有什么:

  • Go devappserver正在运行
  • 一个想要向devappserver数据存储区发出查询的Go独立二进制文件。
  • 我们安装了('go get')google-api-go-client / datastore / v1beta2,以便我们可以使用API​​而不是发出直接的HTTP调用。但是,如果此API库无法在开发中使用,我们肯定愿意发出直接的HTTP调用。
  • 我们设置了服务帐户(我们已经从GCE访问GCS)但我怀疑这与本地运行有关...

我见过一些文档,但他们(a)只谈论Python& Java,以及(b)讨论连接到(独立)开发数据存储区服务器,而不是嵌入在AppEngine的devappserver中的数据存储区(如果它们甚至不同?)。 StackOverflow上还有以下答案,但它再次讨论了连接到独立开发数据存储区服务器的问题:

How to connect to the local google cloud Datastore db?

任何指针都会非常感激!

  • 伊恩

2 个答案:

答案 0 :(得分:4)

目前,由于多种原因,这在开发环境中是不可能的。 Google Cloud数据存储区工具( gcd.sh )使用java开发服务器。但是在开发App Engine时,你需要使用python开发服务器,它有不同的底层存储。在github page上有一个跟踪此问题的错误。

您仍然可以开发Google Cloud Datoreore应用程序,但当前的go客户端库中有many bugs。不幸的是,开发服务器目前不支持go库使用的JSON API(参见note at the top of the page)。

更新:我想确保将proppy的评论视为答案的一部分。他的建议确实提供了一种使用API​​协议版本的方法,它可能比上面的go客户端库更稳定。它还可以让您使用gcd.sh工具在开发服务器中对此进行测试。您必须自己制作HTTP请求,否则您将无法在应用程序与开发中的云数据存储区之间共享数据存储区中的数据。但是,这绝对是一个很好的解决方法,并允许您使用Cloud Datastore API,因为它开发比其他解决方案更容易使用。 来自proppy:

  

请注意,您仍然可以在Go中使用Cloud Datastore Protobuf HTTP API。 protobuf定义在GitHub上可用,您可以使用Go protobuf编译器插件将其编译为Go代码,然后将POST HTTP请求发送到/datastore/{version}/datasets/{datasetId}/{method}

答案 1 :(得分:0)

如果“GO”应用服务器中的用例足够直接,您可能希望通过使用对GAE服务的API调用来实现访问(可能会扩展服务以接收API调用)。

如果您的数据存储定义或功能发生变化,这样做的另一个好处就是只需在一个地方进行更改。