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 运行时中是不可行的。
随着 GAE 标准的 Go 1.11 运行时的引入,上下文范围限制已经放宽。现在,您可以使用您喜欢的任何上下文。
在新的 GAE 标准运行时中,建议:
使用后台在main()或init()函数中初始化Firestore客户端context:
func init() { var err error client, err = firestore.NewClient(context.Background()) }
在请求处理程序中,使用请求上下文进行 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中文网其他相关文章!