주요 콘텐츠로 건너뛰기 이 브라우저는 더 이상 지원되지 않습니다. Show 최신 기능, 보안 업데이트, 기술 지원을 이용하려면 Microsoft Edge로 업그레이드하세요. Azure Database for PostgreSQL - 유연한 서버의 PostgreSQL 확장
이 문서의 내용적용 대상: Azure Database for PostgreSQL - 유연한 서버PostgreSQL은 확장을 사용하여 데이터베이스의 기능을 확장하는 방법을 제공합니다. 확장은 명령을 사용하여 데이터베이스에서 로드하거나 제거할 수 있는 단일 패키지에서 여러 관련 SQL 개체를 함께 번들로 묶습니다. 데이터베이스에 로드한 확장은 기본 제공 기능처럼 작동합니다. PostgreSQL 확장을 사용하는 방법Azure Database for PostgreSQL - 유연한 서버에 확장을 설치하려면 먼저 이러한 확장을 사용하도록 허용 목록에 추가해야 합니다. Azure Portal 사용:
Azure CLI 사용: CLI 매개 변수 설정 명령을 통해 확장을 허용 목록에 추가할 수 있습니다.
ARM 템플릿 사용: 아래 예제에서는 mypostgreserver 서버의 dblink, dict_xsyn, pg_buffercache 확장을 허용 목록으로 지정합니다.
Shared_Preload_Libraries는 PostgreSQL이 시작될 때 로드할 라이브러리를 결정하는 서버 구성 매개 변수입니다. 공유 메모리를 사용하는 모든 라이브러리는 이 매개 변수를 통해 로드해야 합니다. 공유 미리 로드 라이브러리에 확장을 추가해야 하는 경우 다음을 수행할 수 있습니다. Azure Portal 사용:
Azure CLI 사용: CLI 매개 변수 설정
확장을 허용 목록으로 나열하고 로드한 후에는 데이터베이스에 설치해야 사용할 수 있습니다. 특정 확장을 설치하려면 CREATE EXTENSION 명령을 실행해야 합니다. 이 명령은 패키지 개체를 데이터베이스에 로드합니다. Azure
Database for PostgreSQL은 아래에 나열된 대로 주요 확장의 일부만 지원합니다. 이 정보를 Postgres 14 확장다음 확장은 Postgres 버전 14가 있는 Azure Database for PostgreSQL - 유연한 서버에서 사용할 수 있습니다. Postgres 13 확장다음 확장은 Postgres 버전 13이 있는 Azure Database for PostgreSQL - 유연한 서버에서 사용할 수 있습니다. Postgres 12 확장다음 확장은 Postgres 버전 12가 있는 Azure Database for PostgreSQL - 유연한 서버에서 사용할 수 있습니다. Postgres 11 확장다음 확장은 Postgres 버전 11이 있는 Azure Database for PostgreSQL - 유연한 서버에서 사용할 수 있습니다. dblink 및 postgres_fdwdblink 및 postgres_fdw를 사용하면 한 PostgreSQL 서버에서 다른 PostgreSQL 서버로 또는 동일한 서버의 다른 데이터베이스로 연결할 수 있습니다. 유연한 서버는 PostgreSQL 서버에 대한 수신/발신 연결을 모두 지원합니다. 발신 서버는 수신 서버에 대한 아웃바운드 연결을 허용해야 합니다. 마찬가지로, 수신 서버는 발신 서버의 연결을 허용해야 합니다. 이와 같은 두 가지 확장을 사용할 계획인 경우 VNet 통합을 이용하여 서버를 배포하는 것이 좋습니다. 기본적으로 VNet 통합은 VNET의 서버 간 연결을 허용합니다. 또한 VNet 네트워크 보안 그룹을 사용하여 액세스를 사용자 지정하도록 선택할 수 있습니다. pg_prewarmpg_prewarm 확장은 관계형 데이터를 캐시에 로드합니다. 캐시를 사전 준비하면 다시 시작한 후 쿼리를 처음 실행할 때 더 나은 응답 시간을 보입니다. 자동 사전 준비 기능은 현재 Azure Database for PostgreSQL - 유연한 서버에서 사용할 수 없습니다. pg_cronpg_cron은 데이터베이스 내부에서 확장으로 실행되는 간단한 PostgreSQL용 cron 기반 작업 스케줄러입니다. pg_cron 확장을 사용하여 PostgreSQL 데이터베이스 내에서 예약된 유지 관리 작업을 실행할 수 있습니다. 예를 들어, 테이블을 주기적으로 정리하거나 오래된 데이터 작업을 제거할 수 있습니다.
몇 가지 예는 다음과 같습니다. 토요일 오전 3시 30분(GMT)에 오래된 데이터를 삭제하려면
기본 데이터베이스 'postgres'에서 매일 오전 10:00(GMT)에 진공을 실행하려면
pg_cron에서 모든 작업의 예약을 취소하려면
현재 pg_cron 예약된 모든 작업을 보려면
azure_pg_admin 역할 계정의 데이터베이스 'testcron'에서 매일 오전 10:00(GMT)에 vaccuum을 실행하려면
참고 pg_cron 확장은 postgres 데이터베이스 내의 모든 Azure Database for PostgreSQL -유연한 서버에 대해 Shared_Preload_Libraries 미리 로드되어 보안을 손상시키지 않고 PostgreSQL DB 인스턴스 내의 다른 데이터베이스에서 실행되도록 작업을 예약할 수 있는 기능을 제공합니다. 그러나 보안상의 이유로 목록 pg_cron 확장을 허용 하고 CREATE EXTENSION 명령을 사용하여 설치해야 합니다. pg_stat_statementspg_stat_statements 확장은 모든 Azure Database for PostgreSQL 유연한 서버에 미리 로드되어 SQL 문의 실행 통계를 추적하는 수단을 제공합니다. 확장을 통해 어떤 명령문을 계산할지 제어하는 pg_stat_statements를 통해 제공되는 쿼리 실행 정보와 각 SQL 문을 기록할 때 서버 성능에 미치는 영향 사이에는 상충 관계가 있습니다. pg_stat_statements 확장을 적극적으로 사용하지
않는 경우에는 TimescaleDBTimescaleDB는 PostgreSQL용 확장으로 패키지된 시계열 데이터베이스입니다. TimescaleDB는 시계열 워크로드에 대한 시간 기반 분석 함수, 최적화 및 스케일링 Postgres를 제공합니다. Timescale, Inc.의 등록 상표인 TimescaleDB에 대한 자세한 정보를 알아봅니다. Azure Database for PostgreSQL은 TimescaleDB Apache-2 버전을 제공합니다. TimescaleDB 설치TimescaleDB를 설치하려면 이를 먼저 서버의 미리 로드된 공유 라이브러리에 포함시켜야 합니다. Postgres의 다음과 같이 Azure Portal을 사용합니다.
이제 Postgres 데이터베이스에서 TimescaleDB를 사용할 수 있습니다. 데이터베이스에 연결하여 다음 명령을 실행합니다.
팁 오류가 표시되면 shared_preload_libraries를 저장한 후 서버를 다시 시작했는지 확인합니다. 이제 TimescaleDB 하이퍼테이블을 처음부터 새로 만들거나 PostgreSQL에서 기존 시계열 데이터를 마이그레이션할 수 있습니다. pg_dump 및 pg_restore를 사용하여 Timescale 데이터베이스 복원pg_dump 및 pg_restore를 사용하여 Timescale 데이터베이스를 복원하려면 대상 데이터베이스에서
먼저 대상 데이터베이스를 준비합니다.
이제 원본 데이터베이스에서 pg_dump를 실행하고 그 다음 pg_restore를 실행합니다. 복원 후 복원된 데이터베이스에서 다음 명령을 반드시 실행하세요.
Timescale 지원 데이터베이스의 복원 방법에 대한 자세한 내용은 Timescale 설명서를 참조하세요. timescaledb-backup을 사용하여 Timescale 데이터베이스 복원위에 나열된
이러한 유틸리티에 대한 자세한 내용은 여기에서 확인할 수 있습니다. 참고
다음 단계사용하려는 확장이 표시되지 않으면 알려주세요. 피드백 포럼에서 기존 요청에 투표하거나 새 피드백 요청을 작성하세요. |