在 Google App Engine (GAE) 中,了解创建 Firestore 客户端的适当方法至关重要。本文通过研究基于上下文的客户端创建以及 GAE 中 Golang 1.11 运行时的最新更改来解决这个问题。
上下文范围的客户端
GAE 使用上下文范围的方法,强调使用 http.Request 中的 context.Context。这意味着每个请求都应该有一个专用的 context.Context 可供客户端库使用。
之前的实现
在早期版本的 GAE 中,创建单个 Firestore客户端并在多个请求中使用它是不切实际的。这是由于 GAE 标准中旧版 Golang 运行时的限制。因此,有必要为每个请求创建一个新的 Firestore 客户端。
Golang 1.11 运行时的当前实现
随着 Golang 1.11 运行时的引入,根据GAE标准,这种情况已经改变。开发人员现在可以选择任何他们想要的 Firestore 客户端初始化上下文。这为使用后台上下文在 main() 或 init() 函数中初始化客户端提供了灵活性。随后,可以使用请求上下文在请求处理程序中进行 API 调用。
惯用方法
当前 GAE 环境中的首选方法是重用 Firestore 客户端实例用于多次调用。以下代码片段举例说明了这种方法:
package main import ( "context" firestore "cloud.google.com/go/firestore" ) var client *firestore.Client func init() { var err error client, err = firestore.NewClient(context.Background(), "my-project-id") // handle errors as needed } func handleRequest(w http.ResponseWriter, r *http.Request) { doc := client.Collection("cities").Doc("Mountain View") doc.Set(r.Context(), someData) // rest of the handler logic }
在此示例中,客户端在 init() 函数中使用后台上下文进行初始化。然后,请求处理程序可以使用 r.Context() 进行 Firestore API 调用。
通过采用这种方法,开发人员可以优化资源利用率并确保 GAE 请求之间的行为一致。
以上是我应该如何在 Google App Engine 中创建 Firestore 客户端?的详细内容。更多信息请关注PHP中文网其他相关文章!