Cloud Run에서는 HTTP(S) 요청을 통해 함수를 호출하려고 할 때 HTTP 함수를 작성합니다. HTTP 시맨틱스를 허용하려면 함수 프레임워크를 사용하고 HTTP 관련 인수를 허용하도록 HTTP 함수 서명을 지정합니다.
HTTP 핸들러 함수 구현
다음 예시에서는 각 런타임의 기본 HTTP 함수 소스 파일을 보여줍니다. 소스 코드를 찾을 위치에 대한 자세한 내용은 소스 디렉터리 구조를 참조하세요.
Node.js
const functions = require('@google-cloud/functions-framework');
// Register an HTTP function with the Functions Framework
functions.http('myHttpFunction', (req, res) => {
// Your code here
// Send an HTTP response
res.send('OK');
});
Node.js에서 Node.js용 함수 프레임워크에 HTTP 핸들러 함수를 등록합니다. HTTP 핸들러 함수는 요청 및 응답 인수를 수락하고 HTTP 응답을 전송하는 Express 미들웨어 함수여야 합니다.
Cloud Run은 body-parser
를 사용하여 요청의 Content-Type
헤더에 따라 요청 본문을 자동으로 파싱하므로 HTTP 핸들러에서 req.body
및 req.rawBody
객체에 액세스할 수 있습니다.
함수 진입점은 함수 프레임워크에 핸들러가 등록된 이름입니다.
이 예시에서 진입점은 myHttpFunction
입니다.
Python
import functions_framework
# Register an HTTP function with the Functions Framework
@functions_framework.http
def my_http_function(request):
# Your code here
# Return an HTTP response
return 'OK'
Python에서는 HTTP 핸들러 함수를 Python용 함수 프레임워크에 등록합니다. HTTP 핸들러 함수는 Flask 요청 객체를 인수로 수락하고 Flask가 HTTP 응답 객체로 변환할 수 있는 값을 반환해야 합니다.
함수 진입점은 함수 프레임워크에 핸들러가 등록된 이름입니다.
이 예시에서 진입점은 my_http_function
입니다.
Go
package myhttpfunction
import (
"fmt"
"net/http"
"github.com/GoogleCloudPlatform/functions-framework-go/functions"
)
func init() {
// Register an HTTP function with the Functions Framework
functions.HTTP("MyHTTPFunction", myHTTPFunction)
}
// Function myHTTPFunction is an HTTP handler
func myHTTPFunction(w http.ResponseWriter, r *http.Request) {
// Your code here
// Send an HTTP response
fmt.Fprintln(w, "OK")
}
Go에서는 init()
함수에서 Go용 함수 프레임워크에 HTTP 핸들러 함수를 등록합니다. HTTP 핸들러 함수는 표준 http.HandlerFunc
인터페이스를 사용하여 HTTP 응답을 전송해야 합니다.
함수 진입점은 함수 프레임워크에 핸들러가 등록된 이름입니다.
이 예시에서 진입점은 MyHTTPFunction
입니다.
HTTP 핸들러 함수는 표준 http.HandlerFunc
인터페이스를 구현해야 합니다. 함수가 요청에 대한 응답을 만드는 데 사용하는 http.ResponseWriter 인터페이스와 인바운드 HTTP 요청의 세부정보가 포함된 http.Request 구조체에 대한 포인터를 받습니다.
자바
package myhttpfunction;
import com.google.cloud.functions.HttpFunction;
import com.google.cloud.functions.HttpRequest;
import com.google.cloud.functions.HttpResponse;
// Define a class that implements the HttpFunction interface
public class MyHttpFunction implements HttpFunction {
// Implement the service() method to handle HTTP requests
@Override
public void service(HttpRequest request, HttpResponse response) throws Exception {
// Your code here
// Send an HTTP response
response.getWriter().write("OK");
}
}
자바에서는 자바용 함수 프레임워크 API를 사용하여 HttpFunction
인터페이스로 HTTP 핸들러 클래스를 구현합니다. service()
메서드는 HTTP 응답을 전송해야 합니다.
함수 진입점은 패키지 이름을 포함하여 HTTP 핸들러 클래스의 정규화된 이름입니다. 이 예시에서 진입점은 myhttpfunction.MyHttpFunction
입니다.
service
메서드는 인바운드 HTTP 요청을 설명하는 HttpRequest
객체와 함수가 응답 메시지로 채우는 HttpResponse
객체를 수신합니다.
.NET
using Google.Cloud.Functions.Framework;
using Microsoft.AspNetCore.Http;
using System.Threading.Tasks;
namespace MyProject
{
// Define a class that implements the IHttpFunction interface
public class MyHttpFunction : IHttpFunction
{
// Implement the HandleAsync() method to handle HTTP requests
public async Task HandleAsync(HttpContext context)
{
// Your code here
// Send an HTTP response
await context.Response.WriteAsync("OK");
}
}
}
.NET 런타임에서는 .NET용 함수 프레임워크를 사용하여 IHttpFunction
인터페이스로 HTTP 핸들러 클래스를 구현합니다. HandleAsync()
메서드는 표준 ASP.NET HttpContext
객체를 인수로 수락하고 HTTP 응답을 전송해야 합니다.
함수 진입점은 네임스페이스를 포함하여 HTTP 핸들러 클래스의 정규화된 이름입니다. 이 예시에서 진입점은 MyProject.MyHttpFunction
입니다.
Ruby
require "functions_framework"
# Register an HTTP function with the Functions Framework
FunctionsFramework.http "my_http_function" do |request|
# Your code here
# Return an HTTP response
"OK"
end
Ruby에서는 Ruby용 함수 프레임워크로 HTTP 핸들러 함수를 등록합니다. HTTP 핸들러 함수는 Rack 요청 객체를 인수로 수락하고 HTTP 응답으로 사용될 수 있는 값을 반환해야 합니다.
함수 진입점은 함수 프레임워크에 핸들러가 등록된 이름입니다.
이 예시에서 진입점은 my_http_function
입니다.
PHP
<?php
use Google\CloudFunctions\FunctionsFramework;
use Psr\Http\Message\ServerRequestInterface;
// Register an HTTP function with the Functions Framework
FunctionsFramework::http('myHttpFunction', 'myHttpHandler');
// Define your HTTP handler
function myHttpHandler(ServerRequestInterface $request): string
{
// Your code here
// Return an HTTP response
return 'OK';
}
PHP에서는 PHP용 함수 프레임워크로 HTTP 핸들러 함수를 등록합니다.
HTTP 핸들러 함수는 PSR-7 ServerRequestInterface
인터페이스를 구현하는 인수를 수락하고 HTTP 응답을 PSR-7 ResponseInterface
인터페이스를 구현하는 문자열 또는 객체로 반환해야 합니다.
함수 진입점은 함수 프레임워크에 핸들러가 등록된 이름입니다.
이 예시에서 진입점은 myHttpFunction
입니다.
HTTP 요청 및 응답
함수 프레임워크에 HTTP 핸들러 함수를 등록하면 HTTP 핸들러가 요청 메서드를 검사하고 메서드에 따라 여러 작업을 실행할 수 있습니다.
Cloud Run 함수에 HTTP 요청을 전송하도록 이벤트 제공업체를 구성하면 함수가 HTTP 응답을 전송합니다. 함수가 백그라운드 작업 (예: 스레드, 미래, JavaScript Promise 객체, 콜백 또는 시스템 프로세스)을 만드는 경우 HTTP 응답을 전송하기 전에 이러한 작업을 종료하거나 해결해야 합니다. HTTP 응답이 전송되기 전에 종료되지 않은 태스크는 완료되지 않을 수 있고 정의되지 않은 동작을 일으킬 수 있습니다.
CORs / CORS 지원 처리
교차 출처 리소스 공유(CORS)는 한 도메인에서 실행되는 애플리케이션이 다른 도메인의 리소스에 액세스하도록 허용하는 한 가지 방법입니다. 예를 들어 사용자 도메인이 함수 액세스를 위해 Cloud Run Functions 도메인에 요청을 수행하도록 허용해야 할 수 있습니다.
함수에 교차 출처 요청을 허용하려면 Access-Control-Allow-Origin
헤더를 HTTP 응답에 따라 적합하게 설정합니다. 프리플라이트된 교차 출처 요청의 경우 204
응답 코드 및 추가 헤더로 프리플라이트 OPTIONS
요청에 응답해야 합니다.
Node.js
Python
Go
자바
.NET
Ruby
PHP
CORS가 올바르게 설정되지 않은 경우 다음과 같은 오류가 표시될 수 있습니다.
XMLHttpRequest cannot load https://YOUR_FUNCTION_URL. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'https://YOUR_DOMAIN' is therefore not allowed access.
CORS 제한사항
프리플라이트된 교차 출처 요청의 경우 프리플라이트 OPTIONS 요청이 Authorization 헤더 없이 전송되므로, 인증이 필요한 모든 HTTP 함수에서 거부됩니다. 프리플라이트 요청이 실패하므로 기본 요청도 실패합니다. 이 제한사항을 해결하려면 다음 옵션 중 하나를 사용하세요.
- 함수에 대해 인증되지 않은 호출을 허용합니다.
- CORS를 방지하기 위해 웹 앱과 Cloud Run을 동일한 도메인에 호스팅합니다. 이렇게 하려면 Firebase 호스팅을 Cloud Run 함수와 통합하면 됩니다.