RDS for PostgreSQL에 대한 메이저 버전 업그레이드를 수행하는 방법
Amazon RDS for PostgreSQL 데이터베이스에서 메이저 버전 업그레이드를 수행할 때 다음 프로세스를 따르는 것이 좋습니다.
-
버전 호환 가능 파라미터 그룹 준비 – 사용자 지정 파라미터 그룹을 사용하는 경우 두 가지 옵션이 있습니다. 새 DB 엔진 버전에 대한 기본 파라미터 그룹을 지정할 수 있습니다. 또는 새 DB 엔진 버전에 대한 사용자 지정 파라미터 그룹을 직접 만들 수도 있습니다. 자세한 내용은 Amazon RDS의 파라미터 그룹 및 다중 AZ DB 클러스터용 DB 클러스터 파라미터 그룹 작업 단원을 참조하세요.
-
지원되지 않는 데이터베이스 클래스 확인 – 데이터베이스의 인스턴스 클래스가 업그레이드하려는 PostgreSQL 버전과 호환되는지 확인합니다. 자세한 내용은 DB 인스턴스 클래스에 지원되는 DB 엔진 단원을 참조하십시오.
-
지원되지 않는 사용 확인:
-
준비된 트랜잭션 – 업그레이드하기 전에 열려 있는 준비된 트랜잭션을 모두 커밋하거나 롤백합니다.
다음 쿼리를 사용하여 데이터베이스에 열려 있는 준비된 트랜잭션이 없음을 확인할 수 있습니다.
SELECT count(*) FROM pg_catalog.pg_prepared_xacts;
-
Reg* 데이터 형식 – 업그레이드를 시도하기 전에 reg* 데이터 형식의 사용을 모두 제거하십시오.
regtype
및regclass
이외에는 reg* 데이터 형식을 업그레이드할 수 없습니다.pg_upgrade
유틸리티는 Amazon RDS에서 업그레이드를 수행하는 데 사용하는 이 데이터 형식을 유지할 수 없습니다.지원되지 않는 reg* 데이터 형식이 사용되지 않음을 확인하려면 각 데이터베이스에 다음 쿼리를 사용합니다.
SELECT count(*) FROM pg_catalog.pg_class c, pg_catalog.pg_namespace n, pg_catalog.pg_attribute a WHERE c.oid = a.attrelid AND NOT a.attisdropped AND a.atttypid IN ('pg_catalog.regproc'::pg_catalog.regtype, 'pg_catalog.regprocedure'::pg_catalog.regtype, 'pg_catalog.regoper'::pg_catalog.regtype, 'pg_catalog.regoperator'::pg_catalog.regtype, 'pg_catalog.regconfig'::pg_catalog.regtype, 'pg_catalog.regdictionary'::pg_catalog.regtype) AND c.relnamespace = n.oid AND n.nspname NOT IN ('pg_catalog', 'information_schema');
-
-
잘못된 데이터베이스 확인:
-
잘못된 데이터베이스가 없는지 확인합니다.
pg_database
카탈로그의datconnlimit
열에는DROP DATABASE
작업 중에 중단된 데이터베이스를 유효하지 않은 것으로 표시하는-2
값이 포함되어 있습니다.다음 쿼리를 사용하여 잘못된 데이터베이스를 확인합니다.
SELECT datname FROM pg_database WHERE datconnlimit = - 2;
-
이전 쿼리는 잘못된 데이터베이스 이름을 반환합니다.
DROP DATABASE
를 사용하여 잘못된 데이터베이스를 삭제할 수 있습니다. 다음 명령을 사용하여 잘못된 데이터베이스를 삭제할 수도 있습니다.invalid_db_name
;SELECT 'DROP DATABASE ' || quote_ident(datname) || ';' FROM pg_database WHERE datconnlimit = -2 \gexec
잘못된 데이터베이스에 대한 자세한 내용은 잘못된 데이터베이스가 있는 autovacuum의 동작 이해를 참조하세요.
-
-
논리적 복제 슬롯 처리 - 데이터베이스에 논리적 복제 슬롯이 있으면 업그레이드할 수 없습니다. 논리적 복제 슬롯은 일반적으로 AWS DMS 마이그레이션 및 데이터베이스에서 데이터 레이크, BI 도구 및 기타 대상으로 테이블을 복제하는 데 사용됩니다. 업그레이드하기 전에 사용 중인 논리적 복제 슬롯의 용도를 알고 삭제해도 되는지 확인합니다. 논리적 복제 슬롯이 계속 사용 중인 경우 삭제하면 안 되며 업그레이드를 진행할 수 없습니다.
논리적 복제 슬롯이 필요하지 않은 경우 다음 SQL을 사용하여 삭제할 수 있습니다.
SELECT * FROM pg_replication_slots; SELECT pg_drop_replication_slot(slot_name);
pglogical
확장을 사용하는 논리적 복제 설정에서도 성공적인 메이저 버전 업그레이드를 위해서는 슬롯을 삭제해야 합니다.pglogical
확장을 사용하여 생성한 슬롯을 식별하고 삭제하는 방법에 대한 자세한 내용은 RDS for PostgreSQL용 논리적 복제 슬롯 관리 단원을 참조하십시오. -
읽기 전용 복제본 처리 – 단일 AZ DB 인스턴스 또는 다중 AZ DB 인스턴스 배포 업그레이드에서는 기본 DB 인스턴스와 함께 리전 내 읽기 전용 복제본도 업그레이드됩니다. Amazon RDS는 다중 AZ DB 클러스터 읽기 전용 복제본은 업그레이드하지 않습니다.
읽기 전용 복제본은 별도로 업그레이드할 수 없습니다. 가능하다 하더라도 기본 및 복제본 데이터베이스가 서로 다른 PostgreSQL 메이저 버전을 갖는 상황이 발생할 수 있습니다. 그런데 읽기 전용 복제본 업그레이드는 프라이머리 DB 인스턴스의 가동 중지 시간을 증가시킬 수 있습니다. 읽기 전용 복제본 업그레이드를 방지하려면 업그레이드 프로세스를 시작하기 전에 복제본을 독립형 인스턴스로 승격하거나 삭제합니다.
업그레이드 과정에서 읽기 전용 복제본 인스턴스의 현재 파라미터 그룹을 기반으로 읽기 전용 복제본의 파라미터 그룹이 다시 생성됩니다. 읽기 전용 복제본을 수정하여 업그레이드가 완료된 후에만 사용자 지정 파라미터 그룹을 읽기 전용 복제본에 적용할 수 있습니다. 읽기 전용 복제본에 대한 자세한 내용은 Amazon RDS for PostgreSQL의 읽기 전용 복제본 작업을(를) 참조하세요.
-
백업 수행 – 메이저 버전 업그레이드를 하기 전에 백업을 수행하여 데이터베이스에 대해 알려진 복원 지점을 생성하는 것이 좋습니다. 백업 보존 기간이 0보다 큰 경우 업그레이드 프로세스는 업그레이드 전후에 데이터베이스의 DB 스냅샷을 생성합니다. 백업 보존 기간을 변경하려면 Amazon RDS DB 인스턴스 수정 및 Amazon RDS용 다중 AZ DB 클러스터 수정 단원을 참조하세요.
백업을 수동으로 수행하려면 Amazon RDS의 단일 AZ DB 인스턴스에 대한 DB 스냅샷 생성 및 Amazon RDS용 다중 AZ DB 클러스터 스냅샷 생성 단원을 참조하세요.
-
메이저 버전 업그레이드 전에 특정 확장 업그레이드 – 업그레이드 시 메이저 버전을 건너뛰려면 메이저 버전 업그레이드를 수행하기 전에 특정 확장을 업데이트해야 합니다. 예를 들어 버전 9.5.x 또는 9.6에서 버전 11.x로 업그레이드하면 메이저 버전을 건너뜁니다. 업데이트할 확장에는 공간 데이터 처리를 위한 PostGIS 및 관련 확장이 포함됩니다.
-
address_standardizer
-
address_standardizer_data_us
-
postgis_raster
-
postgis_tiger_geocoder
-
postgis_topology
사용 중인 각 확장에 대해 다음 명령을 실행합니다.
ALTER EXTENSION
PostgreSQL-extension
UPDATE TO 'new-version
';자세한 내용은 RDS for PostgreSQL 데이터베이스에서 PostgreSQL 확장 업그레이드을 참조하세요. PostGIS 업그레이드에 대한 자세한 내용은 6단계: PostGIS 확장 업그레이드 섹션을 참조하세요.
-
-
메이저 버전 업그레이드 전에 특정 확장 삭제 – 메이저 버전을 버전 11.x로 건너뛰는 업그레이드는
pgRouting
확장 업데이트를 지원하지 않습니다. 버전 9.4.x, 9.5.x 또는 9.6.x에서 버전 11.x로 업그레이드하면 메이저 버전을 건너뜁니다.pgRouting
확장을 삭제한 다음 업그레이드 후에 호환 가능한 버전으로 다시 설치하는 것이 안전합니다. 업데이트할 수 있는 확장 버전에 대한 자세한 내용은 지원되는 PostgreSQL 확장 버전 단원을 참조하십시오.PostgreSQL 버전 11 이상에서는
tsearch2
및chkpass
확장이 더 이상 지원되지 않습니다. 버전 11.x로 업그레이드하는 경우 업그레이드 전에tsearch2
및chkpass
확장을 삭제합니다. -
알 수 없는 데이터 형식 삭제 – 대상 버전에 따라
unknown
데이터 형식을 삭제합니다.PostgreSQL 버전 10은
unknown
데이터 형식에 대한 지원이 중지되었습니다. 버전 9.6 데이터베이스가unknown
데이터 형식을 사용하는 경우 버전 10으로 업그레이드하면 다음과 같은 오류 메시지가 표시됩니다.Database instance is in a state that cannot be upgraded: PreUpgrade checks failed: The instance could not be upgraded because the 'unknown' data type is used in user tables. Please remove all usages of the 'unknown' data type and try again."
문제가 되는 열을 제거하거나 지원되는 데이터 형식으로 변경할 수 있도록 데이터베이스에서
unknown
데이터 형식을 찾으려면 다음 SQL을 사용합니다.SELECT DISTINCT data_type FROM information_schema.columns WHERE data_type ILIKE 'unknown';
-
업그레이드 모의 실습 수행 – 프로덕션 데이터베이스에서 업그레이드를 수행하기 전에 프로덕션 데이터베이스의 복제본에서 메이저 버전 업그레이드를 테스트하는 것이 좋습니다. 중복 테스트 데이터베이스의 실행 계획을 모니터링하여 실행 계획 회귀가 발생할 수 있는지 확인하고 성능을 평가할 수 있습니다. 중복 테스트 인스턴스를 만들려면 최근 스냅샷에서 데이터베이스를 복원하거나 데이터베이스의 특정 시점 복원을 수행하여 최근 복원 가능 시간으로 복원할 수 있습니다.
자세한 내용은 스냅샷에서 복원 또는 Amazon RDS에서 DB 인스턴스를 지정된 시간으로 복원 섹션을 참조하세요. 다중 AZ DB 클러스터의 경우 스냅샷에서 다중 AZ DB 클러스터로 복원 및 다중 AZ DB 클러스터를 특정 시점으로 복원 단원을 참조하세요.
업그레이드 수행에 대한 자세한 내용은 엔진 버전 수동 업그레이드 단원을 참조하세요.
버전 9.6 데이터베이스를 버전 10으로 업그레이드할 때 PostgreSQL 10은 기본적으로 병렬 쿼리를 활성화한다는 점에 유의하세요. 테스트 데이터베이스의
max_parallel_workers_per_gather
파라미터를 2로 변경하여 업그레이드 전에 병렬 처리의 영향을 테스트할 수 있습니다.참고
default.postgresql10
DB 파라미터 그룹의max_parallel_workers_per_gather
파라미터 기본값은 2입니다.자세한 내용은 PostgreSQL 설명서의 Parallel Query
(병렬 쿼리)를 참조하세요. 버전 10에서 병렬 처리를 사용 중지하려면 max_parallel_workers_per_gather
파라미터를 0으로 설정합니다.메이저 버전 업그레이드 중에
public
및template1
데이터베이스와 각 데이터베이스에 있는public
스키마의 이름이 일시적으로 변경됩니다. 이러한 객체는 원래 이름 뒤에 임의의 문자열이 추가된 상태로 로그에 표시됩니다. 그러면locale
및owner
와 같은 사용자 지정 설정이 메이저 버전 업그레이드 중에 유지되도록 문자열이 추가됩니다. 업그레이드가 완료되면 객체의 이름이 원래 이름으로 다시 변경됩니다.참고
메이저 버전 업그레이드 프로세스 중에는 DB 인스턴스 또는 다중 AZ DB 클러스터의 특정 시점으로 복원을 수행할 수 없습니다. Amazon RDS에서 업그레이드가 수행된 후 데이터베이스 자동 백업이 수행됩니다. 업그레이드를 시작하기 이전의 시간 및 데이터베이스 자동 백업을 완료한 이후의 시간으로 특정 시점 복원을 수행할 수 있습니다.
-
사전 확인 절차 오류로 업그레이드가 실패하는 경우 문제 해결 – 메이저 버전 업그레이드 과정에서 Amazon RDS for PostgreSQL은 먼저 사전 확인 절차를 실행하여 업그레이드 실패를 일으킬 수 있는 문제를 식별합니다. 사전 확인 절차는 인스턴스의 모든 데이터베이스에서 호환되지 않는 모든 잠재적 조건을 확인합니다.
사전 확인 시 문제가 발생하면 업그레이드 사전 확인이 실패했음을 나타내는 로그 이벤트가 생성됩니다. 사전 확인 프로세스 세부 정보는 데이터베이스의 모든 데이터베이스에 대해
pg_upgrade_precheck.log
라는 업그레이드 로그에 있습니다. Amazon RDS는 파일 이름에 타임스탬프를 추가합니다. 로그 보기에 대한 자세한 내용은 Amazon RDS 로그 파일 모니터링 단원을 참조하세요.사전 확인 시 복제본 업그레이드가 실패하면 실패한 복제본에 대한 복제가 중단되고 복제본이 종료 상태가 됩니다. 해당 읽기 전용 복제본을 삭제하고 업그레이드된 프라이머리 DB 인스턴스를 기반으로 새 읽기 전용 복제본을 다시 생성합니다.
사전 확인 로그에서 식별된 모든 문제점을 해결한 후 메이저 버전 업그레이드를 다시 시도하세요. 다음은 사전 확인 로그의 예제입니다.
------------------------------------------------------------------------ Upgrade could not be run on Wed Apr 4 18:30:52 2018 ------------------------------------------------------------------------- The instance could not be upgraded from 9.6.11 to 10.6 for the following reasons. Please take appropriate action on databases that have usage incompatible with the requested major engine version upgrade and try the upgrade again. * There are uncommitted prepared transactions. Please commit or rollback all prepared transactions.* One or more role names start with 'pg_'. Rename all role names that start with 'pg_'. * The following issues in the database 'my"million$"db' need to be corrected before upgrading:** The ["line","reg*"] data types are used in user tables. Remove all usage of these data types. ** The database name contains characters that are not supported by RDS for PostgreSQL. Rename the database. ** The database has extensions installed that are not supported on the target database version. Drop the following extensions from your database: ["tsearch2"]. * The following issues in the database 'mydb' need to be corrected before upgrading:** The database has views or materialized views that depend on 'pg_stat_activity'. Drop the views.
-
데이터베이스를 업그레이드하는 동안 읽기 전용 복제본 업그레이드가 실패할 경우 문제 해결 – 실패한 읽기 전용 복제본이
incompatible-restore
상태가 되고 데이터베이스에서 복제가 종료됩니다. 해당 읽기 전용 복제본을 삭제하고 업그레이드된 프라이머리 DB 인스턴스를 기반으로 새 읽기 전용 복제본을 다시 생성합니다.참고
Amazon RDS는 다중 AZ DB 클러스터의 읽기 전용 복제본을 업그레이드하지 않습니다. 다중 AZ DB 클러스터의 메이저 버전 업그레이드를 수행하면, 읽기 전용 복제본의 복제 상태가 종료로 변경됩니다.
다음과 같은 이유로 읽기 전용 복제본 업그레이드가 실패할 수 있습니다.
-
대기 시간이 지난 후에도 프라이머리 DB 인스턴스를 따라잡지 못했습니다.
-
storage-full, incompatible-restore 등과 같이 종료 또는 호환되지 않는 수명 주기 상태에 있었습니다.
-
프라이머리 DB 인스턴스 업그레이드가 시작되었을 때 읽기 전용 복제본에서 별도의 마이너 버전 업그레이드가 실행되었습니다.
-
읽기 전용 복제본에서 호환되지 않는 파라미터를 사용했습니다.
-
읽기 전용 복제본이 프라이머리 DB 인스턴스와 통신하여 데이터 폴더를 동기화하지 못했습니다.
-
-
프로덕션 데이터베이스 업그레이드 – 메이저 버전 업그레이드의 모의 실습이 성공한 경우 안심하고 프로덕션 데이터베이스를 업그레이드해도 됩니다. 자세한 내용은 엔진 버전 수동 업그레이드 단원을 참조하십시오.
-
ANALYZE
작업을 실행하여pg_statistic
테이블을 새로 고칩니다. 모든 PostgreSQL 데이터베이스의 각 데이터베이스에 대해 이 작업을 수행해야 합니다. 옵티마이저 통계는 메이저 버전 업그레이드 중에 전송되지 않으므로 성능 문제를 방지하려면 모든 통계를 다시 생성해야 합니다. 파라미터 없이 명령을 실행하여 다음과 같이 현재 데이터베이스의 모든 일반 테이블에 대한 통계를 생성합니다.ANALYZE VERBOSE;
VERBOSE
플래그는 선택 사항이지만 이 플래그를 사용하면 진행 상황이 표시됩니다. 자세한 내용은 PostgreSQL 설명서의 ANALYZE를 참조하세요. 참고
성능 문제를 방지하려면 업그레이드 후 시스템에서 ANALYZE를 실행합니다.
메이저 버전 업그레이드가 완료된 후에는 다음 작업을 수행하는 것이 좋습니다.
-
PostgreSQL 업그레이드는 PostgreSQL 확장 버전을 업그레이드하지 않습니다. 확장을 업그레이드하려면 RDS for PostgreSQL 데이터베이스에서 PostgreSQL 확장 업그레이드 단원을 참조하십시오.
-
필요할 경우 Amazon RDS를 사용하여
pg_upgrade
유틸리티에서 생성되는 2개의 로그를 표시합니다. 이러한 로그는pg_upgrade_internal.log
및pg_upgrade_server.log
입니다. Amazon RDS는 이러한 로그의 파일 이름에 타임스탬프를 추가합니다. 다른 로그와 마찬가지로 이러한 로그를 볼 수 있습니다. 자세한 내용은 Amazon RDS 로그 파일 모니터링 섹션을 참조하세요.업그레이드 로그를 Amazon CloudWatch Logs에 업로드할 수도 있습니다. 자세한 내용은 Amazon CloudWatch Logs에 PostgreSQL 로그 게시 섹션을 참조하세요.
-
모든 사항이 예상대로 작동하는지 확인하려면 비슷한 워크로드로 업그레이드된 데이터베이스에서 애플리케이션을 테스트합니다. 업그레이드를 확인한 후 이 테스트 인스턴스를 삭제할 수 있습니다.