首页  >  文章  >  后端开发  >  Google App Engine 中的 Firestore 客户端:按请求还是全局?

Google App Engine 中的 Firestore 客户端:按请求还是全局?

Linda Hamilton
Linda Hamilton原创
2024-11-25 11:45:15506浏览

Firestore Client in Google App Engine: Per-Request or Global?

在 Google App Engine 中创建 Firestore 客户端:按请求还是全局?

Google App Engine 中的上下文感知

Google App Engine (GAE)建议对每个客户端库使用范围为 HTTP 请求的 context.Context。这确保客户端与特定请求相关联,为数据库操作提供上下文特定的数据。

每个请求与全局客户端

每个请求方法:

在提供的示例中,在处理函数中为每个request:

func (s *server) person(ctx context.Context, id int) {
    _, err := s.db.Client.Collection("people").Doc(uid).Set(ctx, p)
}

虽然这种方法确保客户端与当前请求隔离,但它可能效率低下并且会带来不必要的开销,特别是对于长时间运行的请求或高频操作。

全局客户端方法:

另一种方法是创建单个全局 Firestore 客户端并将其重用于多个请求。然而,这在 GAE 中的旧 Go 运行时中是不可行的。

新的 Go 1.11 运行时

随着 GAE 标准的 Go 1.11 运行时的引入,上下文范围限制已经放宽。现在,您可以使用您喜欢的任何上下文。

Go 1.11 和 Firestore 的最佳实践

在新的 GAE 标准运行时中,建议:

  1. 使用后台在main()或init()函数中初始化Firestore客户端context:

    func init() {
     var err error
     client, err = firestore.NewClient(context.Background())
    }
  2. 在请求处理程序中,使用请求上下文进行 API 调用:

    func handleRequest(w http.ResponseWriter, r *http.Request) {
     doc := client.Collection("cities").Doc("Mountain View")
     doc.Set(r.Context(), someData)
    }

通过遵循以下最佳实践,您可以利用重用全局 Firestore 客户端所带来的效率提升,同时仍然在数据库操作中维护特定于请求的上下文。

以上是Google App Engine 中的 Firestore 客户端:按请求还是全局?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn