서버리스 VPC 액세스를 사용하여 Cloud Run 함수에서 Redis 인스턴스에 연결할 수 있습니다.
설정
이미 Google Cloud CLI를 설치하고 Redis 인스턴스를 만들었다면 아래 단계를 건너뛸 수 있습니다.
gcloud CLI를 설치하고 초기화합니다.
gcloud init
빠른 시작 가이드에 따라 Redis 인스턴스를 만듭니다. Redis 인스턴스의 영역, IP 주소, 포트를 기록합니다.
서버리스 VPC 액세스 구성
Cloud Run 함수에서 Redis 인스턴스의 승인된 VPC 네트워크에 연결하려면 서버리스 VPC 액세스를 설정해야 합니다.
다음 명령어를 실행하여 Redis 인스턴스의 승인된 네트워크를 찾습니다.
gcloud redis instances describe INSTANCE_ID --region REGION
커넥터 만들기의 안내에 따라 서버리스 VPC 액세스 커넥터를 만듭니다. 함수를 배포하려는 리전과 동일한 리전에 커넥터를 만들고 커넥터가 Redis 인스턴스의 승인된 VPC 네트워크에 연결되어 있는지 확인합니다. 커넥터의 이름을 기억하세요.
샘플 함수
이 샘플 함수는 Cloud Run 함수에서 Redis 인스턴스에 연결을 설정합니다.
원하는 프로그래밍 언어의 저장소를 클론하고 샘플 코드가 포함된 폴더로 이동합니다.
Go
git clone https://github.com/GoogleCloudPlatform/golang-samples
cd golang-samples/functions/memorystore/redis
Node.js
git clone https://github.com/GoogleCloudPlatform/nodejs-docs-samples
cd nodejs-docs-samples/functions/memorystore/redis
Python
git clone https://github.com/GoogleCloudPlatform/python-docs-samples
cd python-docs-samples/functions/memorystore/redis
샘플 코드는 함수가 트리거될 때마다 Redis 카운터를 증가시킵니다.
Go
이 함수는 github.com/gomodule/redigo/redis
클라이언트를 사용합니다.
Node.js
이 함수는 redis
모듈을 사용합니다.
Python
이 함수는 redis-py
패키지를 사용합니다.
Cloud Run 함수에 샘플 배포
Google Cloud CLI를 사용하여 함수를 배포합니다.
Go
gcloud functions deploy visit-count \ --gen2 \ --region=REGION \ --runtime=go116 \ --source=. \ --entry-point=VisitCount \ --trigger-http \ --vpc-connector=projects/PROJECT_ID/locations/REGION/connectors/CONNECTOR_NAME \ --set-env-vars=REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
Node.js
gcloud functions deploy visit-count \ --gen2 \ --region=REGION \ --runtime=nodejs16 \ --source=. \ --entry-point=visitCount \ --trigger-http \ --vpc-connector=projects/PROJECT_ID/locations/REGION/connectors/CONNECTOR_NAME \ --set-env-vars=REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
Python
gcloud functions deploy visit-count \ --gen2 \ --region=REGION \ --runtime=python310 \ --source=. \ --entry-point=visit_count \ --trigger-http \ --vpc-connector=projects/PROJECT_ID/locations/REGION/connectors/CONNECTOR_NAME \ --set-env-vars=REDISHOST=REDIS_IP,REDISPORT=REDIS_PORT
각 항목의 의미는 다음과 같습니다.
PROJECT_ID
는 Google Cloud 프로젝트의 ID입니다.REGION
은 함수를 배포하려는 리전입니다.CONNECTOR_NAME
은 커넥터의 이름입니다.REDIS_IP
및REDIS_PORT
는 Redis 인스턴스의 IP 주소 및 포트 번호입니다.
함수 배포가 완료되면 함수 URL을 검색합니다.
gcloud functions describe visit-count \ --gen2 \ --region=REGION \ --format="value(serviceConfig.uri)"
URL에 GET
요청을 전송하여 함수를 트리거할 때마다 카운터 증가를 확인할 수 있습니다.