AWS SCT를 사용하여 스키마, 데이터베이스 코드 객체 및 애플리케이션 코드를 PostgreSQL에서 다음 대상으로 변환할 수 있습니다.
Amazon RDS for MySQL
Amazon Aurora MySQL 호환 버전
Amazon RDS for PostgreSQL
Amazon Aurora PostgreSQL 호환 에디션
자세한 내용은 다음 단원을 참조하세요.
PostgreSQL을 소스 데이터베이스로 사용할 수 있는 권한
PostgreSQL을 소스로 사용하기 위해 필요한 권한은 다음과 같습니다.
-
CONNECT ON DATABASE
<database_name>
-
USAGE ON SCHEMA
<database_name>
-
SELECT ON ALL TABLES IN SCHEMA
<database_name>
-
SELECT ON ALL SEQUENCES IN SCHEMA
<database_name>
PostgreSQL에 소스로 연결
다음 절차에 따라 AWS Schema Conversion Tool을 사용하여 PostgreSQL 소스 데이터베이스에 연결합니다.
PostgreSQL 소스 데이터베이스에 연결하려면
-
AWS Schema Conversion Tool에서 소스 추가를 선택합니다.
-
PostgreSQL을 선택한 후 다음을 선택합니다.
소스 추가 대화 상자가 나타납니다.
-
연결 이름에 데이터베이스의 이름을 입력합니다. AWS SCT는 왼쪽 패널의 트리에 이 이름을 표시합니다.
-
AWS Secrets Manager의 데이터베이스 보안 인증 정보를 사용하거나 수동으로 입력합니다.
-
Secrets Manager의 데이터베이스 보안 인증 정보를 사용하려면 다음 지침을 따릅니다.
-
AWS Secret에서 보안 암호의 이름을 선택합니다.
-
Populate를 선택하여 Secrets Manager에서 데이터베이스 연결 대화 상자에 있는 모든 값을 자동으로 채웁니다.
Secrets Manager의 데이터베이스 보안 인증 사용에 대한 자세한 내용은 AWS Schema Conversion Tool에서 AWS Secrets Manager 구성 섹션을 참조하세요.
-
-
PostgreSQL 소스 데이터베이스 연결 정보를 수동으로 입력하려면 다음 지침을 사용합니다.
파라미터 작업 [서버 이름] 소스 데이터베이스 서버의 도메인 이름 시스템(DNS) 이름 또는 IP 주소를 입력합니다.
IPv6 주소 프로토콜을 사용하여 소스 PostgreSQL 데이터베이스에 연결할 수 있습니다. 이렇게 하려면 다음 예제와 같이 대괄호를 사용하여 IP 주소를 입력해야 합니다.
[2001:db8:ffff:ffff:ffff:ffff:ffff:fffe]
[Server port] 소스 데이터베이스 서버에 연결하는 데 사용되는 포트를 입력합니다.
데이터베이스 PostgreSQL 데이터베이스의 이름을 입력합니다.
User name 및 Password 소스 데이터베이스 서버에 연결하는 데 필요한 데이터베이스 보안 인증 정보를 입력합니다.
프로젝트에서 데이터베이스에 연결하도록 선택한 경우에만 AWS SCT에서 암호를 사용하여 소스 데이터베이스에 연결합니다. 소스 데이터베이스의 암호가 노출될 위험을 방지하기 위해 AWS SCT는 기본적으로 암호를 저장하지 않습니다. AWS SCT 프로젝트를 닫았다 다시 열 경우 필요에 따라 소스 데이터베이스에 연결하기 위한 암호를 입력하라는 메시지가 표시됩니다.
Use SSL(SSL 사용) SSL(Secure Sockets Layer)을 사용하여 데이터베이스에 연결하려면 이 옵션을 선택합니다. SSL 탭에서 다음 추가 정보를 적절히 제공합니다.
-
Verify server certificate: 트러스트 스토어를 사용하여 서버 인증서를 확인하려면 이 옵션을 선택합니다.
-
트러스트 스토어: 인증서가 있는 트러스트 스토어의 위치입니다. 이 위치가 전역 설정 섹션에 표시되도록 하려면 해당 위치를 추가해야 합니다.
Store password AWS SCT는 SSL 인증서와 데이터베이스 암호를 저장할 안전한 볼트를 생성합니다. 이 옵션을 활성화하면 데이터베이스 암호를 저장하고 암호 입력 없이 빠르게 데이터베이스에 연결할 수 있습니다.
PostgreSQL driver path 소스 데이터베이스에 연결할 때 사용할 드라이버의 경로를 입력합니다. 자세한 내용은 AWS Schema Conversion Tool용 JDBC 드라이버 설치 단원을 참조하십시오.
드라이버 경로를 전역 프로젝트 설정에 저장할 경우 드라이버 경로가 연결 대화 상자에 표시되지 않습니다. 자세한 내용은 전역 설정에 드라이버 경로 저장 단원을 참조하십시오.
-
-
-
Test Connection을 선택하여 AWS SCT가 소스 데이터베이스에 연결할 수 있는지 확인합니다.
-
연결을 선택하여 소스 데이터베이스에 연결합니다.
MySQL을 대상 데이터베이스로 사용하기 위한 권한
PostgreSQL에서 마이그레이션할 때 MySQL을 대상으로 사용하기 위해 필요한 권한은 다음과 같습니다.
CREATE ON *.*
ALTER ON *.*
DROP ON *.*
INDEX ON *.*
REFERENCES ON *.*
SELECT ON *.*
CREATE VIEW ON *.*
SHOW VIEW ON *.*
TRIGGER ON *.*
CREATE ROUTINE ON *.*
ALTER ROUTINE ON *.*
EXECUTE ON *.*
INSERT, UPDATE ON AWS_POSTGRESQL_EXT.*
INSERT, UPDATE, DELETE ON AWS_POSTGRESQL_EXT_DATA.*
CREATE TEMPORARY TABLES ON AWS_POSTGRESQL_EXT_DATA.*
다음 코드 예제를 사용하여 데이터베이스 사용자를 생성하고 권한을 부여할 수 있습니다.
CREATE USER '
user_name
' IDENTIFIED BY 'your_password
'; GRANT CREATE ON *.* TO 'user_name
'; GRANT ALTER ON *.* TO 'user_name
'; GRANT DROP ON *.* TO 'user_name
'; GRANT INDEX ON *.* TO 'user_name
'; GRANT REFERENCES ON *.* TO 'user_name
'; GRANT SELECT ON *.* TO 'user_name
'; GRANT CREATE VIEW ON *.* TO 'user_name
'; GRANT SHOW VIEW ON *.* TO 'user_name
'; GRANT TRIGGER ON *.* TO 'user_name
'; GRANT CREATE ROUTINE ON *.* TO 'user_name
'; GRANT ALTER ROUTINE ON *.* TO 'user_name
'; GRANT EXECUTE ON *.* TO 'user_name
'; GRANT INSERT, UPDATE ON AWS_POSTGRESQL_EXT.* TO 'user_name
'; GRANT INSERT, UPDATE, DELETE ON AWS_POSTGRESQL_EXT_DATA.* TO 'user_name
'; GRANT CREATE TEMPORARY TABLES ON AWS_POSTGRESQL_EXT_DATA.* TO 'user_name
';
이전 예제에서 user_name
을 사용자 이름으로 바꿉니다. 그런 다음 your_password
를 안전한 암호로 바꿉니다.
Amazon RDS for MySQL 또는 Amazon RDS for Aurora MySQL을 대상으로 사용하려면 lower_case_table_names
파라미터를 1
로 설정합니다. 이 값은 MySQL 서버가 테이블, 인덱스, 트리거 및 데이터베이스와 같은 객체 이름의 식별자를 대소문자 구분 없이 처리한다는 것을 의미합니다. 대상 인스턴스에서 이진 로깅을 활성화했다면 log_bin_trust_function_creators
파라미터를 1
로 설정합니다. 이 경우 저장된 함수를 생성하기 위해 DETERMINISTIC
, READS SQL DATA
또는 NO SQL
특성을 사용할 필요가 없습니다. 이들 파라미터를 구성하려면 새 DB 파라미터 그룹을 생성하거나 기존 DB 파라미터 그룹을 수정해야 합니다.