Home >Backend Development >Golang >Firestore Client Creation in Google App Engine: Single Client or Per Request?

Firestore Client Creation in Google App Engine: Single Client or Per Request?

Mary-Kate Olsen
Mary-Kate OlsenOriginal
2024-11-19 21:55:03653browse

Firestore Client Creation in Google App Engine: Single Client or Per Request?

Client Creation for Firestore in Google App Engine: Single or Per Request?

Pattern for Client Creation

In Google App Engine, the general recommendation is to reuse the firestore.Client instance for multiple invocations. However, whether a single client or a per-request client is more appropriate depends on the specific version of App Engine used:

App Engine Standard with Go 1.11 Runtime:

With the Go 1.11 runtime, any context can be utilized to initialize the firestore.Client. This allows for client creation in the main() function or any other function that uses the background context. API calls can then be made within request handlers using the request context.

package main

var client *firestore.Client

func init() {
  var err error
  client, err = firestore.NewClient(context.Background())
  // 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
}

App Engine Standard with Go Runtime Prior to 1.11:

In the older Go runtimes, App Engine enforced the use of context scoped to an HTTP request for all client library instances. Consequently, a new firestore.Client had to be created per request:

func main() {
    // Setup server
    s := &server{db: NewFirestoreClient()}

    // Setup Router
    http.HandleFunc("/people", s.peopleHandler())

    // Starts the server to receive requests
    appengine.Main()
}

func (s *server) peopleHandler() http.HandlerFunc {
    // pass context in this closure from main?
    return func(w http.ResponseWriter, r *http.Request) {
        ctx := r.Context() // appengine.NewContext(r) but should it inherit from background somehow?
        s.person(ctx, 1)
        // ...
    }
}

func (s *server) person(ctx context.Context, id int) {
    // what context should this be?
    _, err := s.db.Client.Collection("people").Doc(uid).Set(ctx, p)
    // handle client results
}

func NewFirestoreClient() *Firestore {
    ctx := context.Background()
    client, err := firestore.NewClient(ctx, os.Getenv("GOOGLE_PROJECT_ID"))
    if err != nil {
        log.Fatal(err)
    }

    return &Firestore{
        Client: client,
    }
}

By following the appropriate client creation pattern based on the App Engine version, you can optimize the performance and resource utilization of your Firestore applications.

The above is the detailed content of Firestore Client Creation in Google App Engine: Single Client or Per Request?. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn