>백엔드 개발 >Golang >Google App Engine에서 Firestore 클라이언트를 어떻게 생성해야 합니까?

Google App Engine에서 Firestore 클라이언트를 어떻게 생성해야 합니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-20 03:44:02625검색

How Should I Create Firestore Clients in Google App Engine?

Google App Engine에서 Firestore 클라이언트 생성

Google App Engine(GAE)에서는 Firestore 클라이언트를 생성하는 적절한 접근 방식을 이해하는 것이 중요합니다. 이 문서에서는 GAE에서 컨텍스트 기반 클라이언트 생성과 Golang 1.11 런타임의 최근 변경 사항을 검토하여 이러한 문제를 해결합니다.

컨텍스트 범위 클라이언트

GAE는 컨텍스트 범위 접근 방식으로 http.Request에서 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.