>  기사  >  백엔드 개발  >  Golang을 사용하는 Cloud Functions Gen2 - 작업이 완료될 때까지 기다리지 않고 인스턴스 수명 주기 및 BigQuery 삽입을 안전하게 수행

Golang을 사용하는 Cloud Functions Gen2 - 작업이 완료될 때까지 기다리지 않고 인스턴스 수명 주기 및 BigQuery 삽입을 안전하게 수행

王林
王林앞으로
2024-02-09 21:33:10432검색

使用 Golang 的 Cloud Functions Gen2 - 实例生命周期和 BigQuery 插入安全,无需等待作业完成

php 편집기 Apple에서는 Golang을 사용하는 Cloud Functions Gen2에 대한 기사를 제공합니다. 이 문서에서는 BigQuery 삽입의 인스턴스 수명 주기와 보안, 그리고 작업이 완료될 때까지 기다리지 않고 이를 수행하는 방법에 중점을 둡니다. 이 기사를 읽으면 애플리케이션의 성능과 보안을 최적화하고 개선하는 방법을 배울 수 있습니다. 이 흥미로운 주제를 함께 살펴보겠습니다!

질문 내용

저는 HTTP 요청에 의해 실행되는 Golang으로 작성된 Google Cloud 함수(Gen2)를 사용하고 있습니다. 내 사용 사례에서는 BigQuery에 일부 데이터를 저장해야 하며 HTTP 요청에 응답하기 전에 작업이 완료될 때까지 기다리지 않으려고 합니다.

하지만 함수에서 반환된 후 Cloud 함수 인스턴스의 동작이 걱정됩니다.

HTTP 응답을 보낸 후 인스턴스는 얼마나 오랫동안 활성 상태로 유지되나요? BigQuery 작업이 완료될 때까지 기다리지 않아도 안전한가요? 작업이 완료되기 전에 인스턴스를 종료하면 데이터가 손실될 위험이 있습니까? 이 시나리오에 관한 통찰력이나 모범 사례를 알려주시면 감사하겠습니다.

해결 방법

이 접근 방식은 권장되지 않습니다. 다음 문서를 참조하세요:

함수 실행 타임라인

함수는 함수 실행 중에만 할당된 리소스(메모리 및 CPU)에 액세스할 수 있습니다. 실행 주기 외부에서 실행되는 코드는 실행이 보장되지 않으며 언제든지 중지될 수 있습니다. 따라서 항상 함수 실행 종료를 적절하게 알리고 함수 실행 범위를 벗어나는 코드를 실행하지 않아야 합니다.

백그라운드 활동을 시작하지 마세요

백그라운드 활동은 함수가 종료된 후에 발생하는 모든 것입니다. 함수가 반환되거나 Node.js 이벤트 기반 함수에서 callback 매개변수를 호출하는 등 완료 신호를 보내면 함수 호출이 완료됩니다. 정상적으로 종료된 후 실행되는 모든 코드는 CPU에 액세스할 수 없으며 진행되지 않습니다.

또한 동일한 환경에서 후속 통화가 이루어지면 백그라운드 활동이 재개되어 새로운 통화를 방해합니다. 이로 인해 예기치 않은 동작과 진단하기 어려운 오류가 발생할 수 있습니다. 기능이 종료된 후 네트워크에 접속하면 일반적으로 연결이 재설정됩니다(ECONNRESET 오류 코드).

백그라운드 활동은 일반적으로 통화 완료 라인 이후에 기록된 내용을 찾아 개별 통화 로그에서 감지할 수 있습니다. 특히 콜백이나 타이머와 같은 비동기 작업이 있는 경우 백그라운드 활동이 코드에 더 깊이 묻혀 있을 수 있습니다. 함수를 종료하기 전에 코드를 확인하여 모든 비동기 작업이 완료되었는지 확인하세요.

또 다른 솔루션은 이를 이벤트 중심 함수로 구현하는 것입니다(Cloud Functions 유형 참조). 그런 다음 이 함수에 대한 Pub/Sub 트리거와 Pub/Sub 주제를 지정합니다(Pub/Sub 트리거 참조). 이 주제에 이벤트를 게시하려면 클라이언트를 다시 작성해야 합니다.

클라이언트를 재정의할 수 없는 경우 해결 방법은 HTTP 기능과 이벤트 기반 기능을 모두 유지하고 주제에 이벤트를 게시하여 HTTP 함수가 작업을 이벤트 기반 기능으로 오프로드하도록 하는 것입니다. 이벤트 크기와 BigQuery 작업 실행 시간에 따라 클라이언트 대기 시간이 줄어들 수도 있습니다. 그리고 저는 이 접근 방식이 상당한 비용을 추가한다고 생각합니다.

위 내용은 Golang을 사용하는 Cloud Functions Gen2 - 작업이 완료될 때까지 기다리지 않고 인스턴스 수명 주기 및 BigQuery 삽입을 안전하게 수행의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 stackoverflow.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제