> 백엔드 개발 > Golang > Go에서 AWS API Gateway 사용: 전체 안내서

Go에서 AWS API Gateway 사용: 전체 안내서

WBOY
풀어 주다: 2023-06-17 16:26:19
원래의
1429명이 탐색했습니다.

클라우드 컴퓨팅의 인기와 발전으로 효율적인 배포 및 관리를 달성하기 위해 클라우드 서비스 공급자를 사용하는 애플리케이션이 점점 더 많아지고 있습니다. 세계 최대의 클라우드 컴퓨팅 서비스 제공업체 중 하나인 AWS의 API 게이트웨이는 클라우드 서비스 구현을 위한 핵심 구성 요소 중 하나입니다. 이 기사에서는 Go 언어로 AWS API Gateway를 사용하여 효율적인 클라우드 서비스를 구축하는 방법을 소개합니다.

1단계: API 게이트웨이 생성

AWS API Gateway를 사용하기 전에 AWS 콘솔에서 API 게이트웨이를 생성해야 합니다. 먼저 AWS 콘솔에서 API Gateway 서비스를 선택한 다음 지침에 따라 API를 생성합니다. API를 생성하는 단계에는 API 이름 정의, 리소스 생성, GET 및 POST 메서드 정의 등이 포함됩니다.

그 중 API 이름을 정의하는 방법은 매우 간단합니다. 프롬프트에 따라 입력하면 됩니다. 리소스를 생성하려면 URL 경로와 메서드를 정의해야 합니다. 예를 들어 URL 경로 "/hello"와 GET 메서드를 정의할 수 있습니다. Amazon Lambda 함수 또는 기타 클라우드 서비스와 같은 각 방법에 일부 통합을 추가합니다.

2단계: Go에서 API Gateway 사용

Go 언어로 API Gateway를 사용하려면 AWS에서 공식적으로 제공하는 SDK를 사용해야 합니다. 먼저, 다음 방법을 통해 다운로드할 수 있는 AWS SDK Go를 설치해야 합니다.

go get github.com/aws/aws-sdk-go
로그인 후 복사

Go 프로그램에서 API Gateway를 사용하려면 AWS SDK Go에서 제공하는 API를 사용해야 합니다. 먼저 API Gateway 클라이언트를 구축해야 합니다. 예:

import (
    "github.com/aws/aws-sdk-go/aws"
    "github.com/aws/aws-sdk-go/aws/session"
    "github.com/aws/aws-sdk-go/service/apigateway"
)

session := session.Must(session.NewSession(&aws.Config{
    Region: aws.String("us-west-2"),
}))
svc := apigateway.New(session)
로그인 후 복사

API Gateway 클라이언트를 생성한 후 API 및 통합 방법에서 리소스와 메서드를 정의해야 합니다. 예:

// 资源和方法
id := "abcde12345"
restAPI := "my-restapi-id"
resourcePath := "/hello"
method := "POST"
contentType := "application/json"

// 定义Lambda函数攻略
integration := &apigateway.Integration{
    IntegrationHttpMethod: aws.String("POST"),
    Type:                  aws.String("AWS_PROXY"),
    Uri:                   aws.String("arn:aws:lambda:us-west-2:MyAccount:function:my-lambda-function"),
}

// 添加方法
params := &apigateway.PutMethodInput{
    RestApiId:    aws.String(restAPI),
    ResourceId:   aws.String(id),
    HttpMethod:   aws.String(method),
    AuthorizationType: aws.String("NONE"),
}

_, err := svc.PutMethod(params)
if err != nil {
    panic(fmt.Sprintf("failed to add method to API Gateway, err: %s", err))
}

// 添加Lambda集成方式
params2 := &apigateway.PutIntegrationInput{
    RestApiId: aws.String(restAPI),
    ResourceId:    aws.String(id),
    HttpMethod:    aws.String(method),
    Integration:   integration,
}

_, err2 := svc.PutIntegration(params2)
if err2 != nil {
    panic(fmt.Sprintf("failed to add integration to API Gateway, err: %s", err2))
}

// 添加响应模版
params3 := &apigateway.PutMethodResponseInput{
    RestApiId:         aws.String(restAPI),
    ResourceId:        aws.String(id),
    HttpMethod:        aws.String(method),
    StatusCode:        aws.String("200"),
    ResponseParameters: map[string]*bool{},
    ResponseModels:    map[string]*string{contentType: aws.String("Empty")},
}
_, err3 := svc.PutMethodResponse(params3)
if err3 != nil {
    panic(fmt.Sprintf("failed to add method response to API Gateway, err: %s", err3))
}

// 更新集成响应模版
params4 := &apigateway.PutIntegrationResponseInput{
    RestApiId: aws.String(restAPI),
    ResourceId:        aws.String(id),
    HttpMethod:        aws.String(method),
    StatusCode:        aws.String("200"),
    ResponseTemplates: map[string]*string{contentType: aws.String("")},
}
_, err4 := svc.PutIntegrationResponse(params4)
if err4 != nil {
    panic(fmt.Sprintf("failed to add integration response to API Gateway, err: %s", err4))
}
로그인 후 복사

리소스와 메서드는 다음과 같습니다. 이 코드 조각에 정의되어 있으며 Lambda 통합 방법이 추가되었습니다. 응답 및 통합 응답 템플릿도 정의됩니다.

3단계: API Gateway 테스트

API Gateway 생성을 완료하고 Go 프로그램을 작성한 후에는 API Gateway가 제대로 작동하는지 테스트해야 합니다. Postman 또는 다른 HTTP 클라이언트를 사용하여 API에 요청을 보내고 응답을 받을 수 있습니다. 예를 들어 다음 명령을 사용하여 API에 POST 요청을 보냅니다.

curl --header "Content-Type: application/json" 
     --request POST 
     --data '{"name":"John","age":30}' 
     https://my-gateway-id.execute-api.us-west-2.amazonaws.com/hello
로그인 후 복사

API 게이트웨이를 성공적으로 테스트한 후 Go 애플리케이션을 배포하고 API 게이트웨이와 통합하여 효율적인 클라우드 서비스를 얻을 수 있습니다.

요약

이 문서에서는 Go 언어로 AWS API Gateway를 사용하는 방법에 대한 완전한 가이드를 제공합니다. API 게이트웨이를 생성하고 리소스 및 메서드, 통합 메서드, 응답 및 통합 응답 템플릿을 정의해야 합니다. 이러한 작업은 AWS SDK Go를 사용하여 쉽게 수행할 수 있습니다. API Gateway를 테스트하고 Go 애플리케이션을 통합한 후 AWS 클라우드 환경에서 효율적인 클라우드 서비스를 구축할 수 있습니다.

위 내용은 Go에서 AWS API Gateway 사용: 전체 안내서의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿