관리형 연결 풀링 개요

이 페이지에서는 관리형 연결 풀링에 대해 소개하고 풀링을 사용하여 Cloud SQL 인스턴스의 데이터베이스 연결 관리를 최적화하는 방법을 설명합니다.

관리형 연결 풀링을 사용하면 풀링을 사용하여 Cloud SQL 인스턴스의 리소스 사용과 연결 지연 시간을 최적화하여 워크로드를 확장할 수 있습니다. 관리형 연결 풀링은 가능한 경우 수신 요청에 서버 연결을 동적으로 할당합니다. 이렇게 하면 연결 급증을 흡수하고 기존 데이터베이스 연결을 재사용하여 특히 확장된 연결의 성능이 크게 향상됩니다. 관리형 연결 풀링은 특정 데이터베이스에 연결하는 대신 풀러 클러스터에 연결하여 워크로드의 연결 시간을 단축하고 확장성을 제공합니다.

각 풀은 고유한 데이터베이스 및 사용자와 연결됩니다. 클라이언트가 인증되면 풀은 풀 내의 유휴 서버 연결 중 하나를 재사용하여 데이터베이스를 서버에 연결하려고 시도합니다. 서버 연결을 사용할 수 없는 경우 데이터베이스를 연결하기 위해 풀에 새 서버 연결을 만듭니다. 사용되는 풀러 수는 인스턴스의 vCPU 코어 수를 기반으로 합니다.

모든 트랜잭션 워크로드에 관리형 연결 풀링을 사용할 수 있지만, 단기 지속 연결이 포함된 애플리케이션이나 연결 급증을 유발하는 애플리케이션에 가장 높은 처리량과 지연 시간 이점을 제공합니다.

장기 지속 연결의 경우 관리형 연결 풀을 사용하는 연결 성능이 직접 연결을 사용할 때보다 약간 낮을 수 있습니다. 이러한 경우 연결 수가 매우 많으면 관리형 연결 풀링에서 연결 확장 기능을 제공합니다. 하지만 일반적으로 장기 지속 연결을 설정하는 애플리케이션의 경우 연결 풀링을 사용하지 않는 것이 좋습니다.

포트에 따라 Identity and Access Management를 사용하여 연결을 보호할 수 있습니다. Cloud SQL의 IAM 작동 방식 및 제한사항에 대한 자세한 내용은 IAM 인증을 참고하세요.

관리형 연결 풀링을 사용 설정하는 방법에 대한 자세한 내용은 관리형 연결 풀링 구성을 참고하세요.

요구사항

관리형 연결 풀링을 사용하려면 인스턴스가 다음 요구사항을 충족해야 합니다.

  • 인스턴스는 Cloud SQL Enterprise Plus 버전 인스턴스여야 합니다.
  • 직접 연결 또는 Cloud SQL 인증 프록시만 사용하여 인스턴스에 연결해야 합니다.
  • 인스턴스가 비공개 서비스 액세스를 사용하도록 설정되어 있고 공개 IP를 사용하거나, Private Service Connect가 사용 설정된 새 인스턴스여야 합니다.
  • 인스턴스에서 새 Cloud SQL 네트워크 아키텍처를 사용해야 합니다.
  • 관리형 연결 풀링을 사용하려면 유지보수 버전 번호가 POSTGRES_$version.R20250727.00_14 이상이어야 합니다. 셀프 서비스 유지보수 수행에 관한 자세한 내용은 셀프 서비스 유지보수 수행을 참고하세요.

Cloud SQL 인스턴스의 관리형 연결 풀링에서 사용되는 포트

관리형 연결 풀링을 사용 설정하면 Cloud SQL 인스턴스에서 데이터베이스 트래픽을 처리하는 데 사용되는 포트가 변경됩니다. 포트에 따라 Identity and Access Management를 사용하여 연결을 보호할 수 있습니다.

관리형 연결 풀링에서 사용되는 포트와 사용 가능한 IAM 옵션은 다음과 같습니다.

  • TCP 포트 5432: Postgres 데이터베이스 서버의 직접 연결에 사용됩니다. psql 클라이언트를 사용하여 직접 연결할 때 사용되는 기본 포트 번호입니다.

  • TCP 포트 6432: 관리형 연결 풀링 서버의 직접 연결에 사용됩니다. 이 포트를 사용하여 연결하려면 psql 클라이언트를 사용하여 직접 연결할 때 psql -p 6432를 지정하세요.

    이 포트를 사용할 때는 IAM 인증 옵션을 사용할 수 있습니다.

  • TCP 포트 3307: 관리형 연결 풀링 서버에서 Cloud SQL 인증 프록시 전용 연결에 사용됩니다. Cloud SQL 인증 프록시를 사용하여 관리형 연결 풀링에 연결하는 경우 이 포트 번호는 Cloud SQL 인증 프록시 클라이언트로 구성되며 변경할 수 없습니다.

    이 포트에서는 IAM 인증 옵션 또는 자동 IAM 데이터베이스 인증을 사용할 수 있습니다.

풀링 옵션

관리형 연결 풀링을 사용하면 pool_mode 매개변수를 사용하여 연결이 풀링되는 방식을 관리할 수 있습니다. 다음 풀링 옵션을 사용할 수 있습니다.

  • transaction(기본값): 트랜잭션 수준에서 연결을 풀링합니다. 연결은 각 트랜잭션이 완료된 후 풀로 반환됩니다. Cloud SQL에서는 수명이 짧은 연결에 transaction 풀링 모드를 사용하는 것을 권장합니다.
  • session: 세션 수준에서 연결을 풀링합니다. 각 세션은 세션 상태를 유지하는 전용 서버 연결을 사용합니다. 이렇게 하면 풀링 효율성이 떨어집니다. 클라이언트가 연결을 끊으면 서버가 연결 풀로 돌아갑니다.

고급 구성 옵션

다음 구성 옵션을 사용하여 관리형 연결 풀링을 맞춤설정할 수 있습니다.

구성 이름 설명
max_pool_size 각 연결 풀에서 데이터베이스 및 사용자 쌍에 허용되는 최대 서버 연결 수입니다. 기본값은 50개 연결입니다.
min_pool_size 각 연결 풀에서 언제든지 사용할 수 있는 최소 서버 연결 수입니다.

서버 연결 수가 min_pool_size보다 작으면 이 설정은 풀에 서버 연결을 더 추가합니다. 이렇게 하면 비활성 기간 후 데이터베이스 부하가 갑자기 증가하는 것을 관리하고 연결을 사용할 수 있도록 준비할 수 있습니다.

기본값은 0개 연결입니다.
max_client_connections 관리형 연결 풀링을 사용할 때 인스턴스에 허용되는 최대 연결 수입니다. 기본값은 5,000개 연결입니다.
max_prepared_statements transaction 풀링 모드에서 지원되는 프로토콜 수준의 이름이 지정되고 준비된 문 명령어의 최대 수입니다.

이 옵션을 0으로 설정하면 준비된 명령문 지원이 사용 중지됩니다. 최적의 성능을 위해 이 값은 데이터베이스에서 일반적으로 사용되는 준비된 문의 수를 초과해야 합니다. 관리형 연결 풀링의 준비된 문 수가 많으면 메모리 사용량이 증가할 수 있습니다.

기본값은 문 0개입니다.
client_connection_idle_timeout 클라이언트 연결이 타임아웃되기 전에 유휴 상태로 유지되는 시간입니다. 이 값의 범위는 0~2,147,483초이며 기본값은 0초입니다.
server_connection_idle_timeout 서버 연결이 타임아웃되기 전에 유휴 상태로 유지되는 시간입니다. 이 값의 범위는 0~2,147,483초이며 기본값은 600초입니다.
query_wait_timeout 쿼리가 타임아웃되기 전에 풀에서 서버 연결을 기다리는 시간입니다.

이 옵션을 0으로 설정하면 사용 중지되어 무기한 클라이언트 대기열이 허용됩니다. 이 옵션을 사용 설정하면 응답하지 않는 서버가 연결을 차단하지 않습니다.

이 값의 범위는 0~2,147,483초이며 기본값은 120초입니다.
ignore_startup_parameters 무시할 매개변수입니다. 기본적으로 관리형 연결 풀링 시작 패킷에서 추적되지 않습니다.
server_lifetime 관리형 연결 풀링이 닫기 전에 서버 연결이 사용되지 않는 최대 시간입니다. 값이 0초로 설정되면 연결이 사용 후 즉시 닫힙니다.

기본값은 3600초입니다.

제한사항

Cloud SQL Enterprise Plus 버전 인스턴스에서 관리형 연결 풀링을 사용할 때는 다음 제한사항을 고려하세요.

  • 기존 인스턴스에서 관리형 연결 풀링을 사용 설정하면 데이터베이스가 다시 시작됩니다.
  • Cloud SQL API를 사용하여 관리형 연결 풀링을 사용 설정, 사용 중지 또는 구성하는 경우 instance.update API에는 다른 인스턴스 구성 업데이트가 포함될 수 없습니다.
  • 관리형 연결 풀링은 Cloud SQL 인증 프록시 버전 2.15.2 이상에서만 사용할 수 있습니다.
  • Cloud SQL Go Language 커넥터를 사용하는 경우 Go 버전은 최소 1.24 이상이어야 합니다. Go 버전 1.23 이하를 사용하는 경우 관리형 연결 풀링을 사용할 때 성능이 제한될 수 있습니다.
  • transaction 풀링 모드에서 관리형 연결 풀링을 사용하는 경우 다음 SQL 기능은 지원되지 않습니다.

    • SET/RESET
    • LISTEN
    • WITH HOLD CURSOR
    • PREPARE/DEALLOCATE
    • PRESERVE/DELETE ROW 임시 테이블
    • LOAD
    • 세션 수준 권고 잠금
  • 포트 3307 및 6432에서 관리형 연결 풀링 풀러에 asyncpg 데이터베이스 인터페이스 라이브러리를 사용하는 경우 관리형 연결 풀링 풀러에서 준비된 문을 지원하도록 max_prepared_statements를 0보다 큰 값으로 업데이트해야 합니다.

  • PostgreSQL용 Cloud SQL 버전 17을 사용하는 경우 sslnegotiation=direct 옵션은 지원되지 않습니다.

  • 관리형 연결 풀링에서는 클라이언트 IP 추적이 지원되지 않습니다. 쿼리 통계에서 클라이언트 IP 주소 저장을 사용 설정하면 클라이언트 IP 주소가 IP 주소 자체가 아닌 local로 표시됩니다.

관리형 연결 풀링에서 사용하는 서버 연결

max_connections 데이터베이스 구성은 관리형 연결 풀링의 풀러가 사용할 수 있는 최대 서버 연결 수를 제한합니다. Cloud SQL에서는 인스턴스의 워크로드 요구사항과 데이터베이스 인스턴스 크기에 따라 이 값을 조정하는 것을 권장합니다. 최대 부하 시 인증 연결 수가 매우 많아질 수 있습니다.

인스턴스에서 기본 max_pool_size인 50개의 풀을 사용하는 경우 데이터베이스에 max_connections 플래그를 설정할 때 관리형 연결 풀링을 위해 CPU당 서버 연결을 15개 이상 예약하는 것이 좋습니다. max_connections 플래그에 대한 자세한 내용은 최대 동시 연결을 참고하세요. 인스턴스의 max_connections 플래그를 수정하려면 데이터베이스 플래그 구성을 참고하세요.

다음 단계