에서 동종 데이터 마이그레이션을 위한 소스로 내SQL 호환 데이터베이스 사용 AWS DMS - AWS 데이터베이스 마이그레이션 서비스

기계 번역으로 제공되는 번역입니다. 제공된 번역과 원본 영어의 내용이 상충하는 경우에는 영어 버전이 우선합니다.

에서 동종 데이터 마이그레이션을 위한 소스로 내SQL 호환 데이터베이스 사용 AWS DMS

에서 My SQL호환 데이터베이스(MySQL 또는 MariaDB)를 소스로 사용할 수 동종 데이터베이스 마이그레이션 있습니다 AWS DMS. 이 경우 소스 데이터 공급자는 온프레미스, Amazon 또는 My EC2SQL 또는 MariaDB 데이터베이스RDS용일 수 있습니다.

동종 데이터 마이그레이션을 실행하려면 모든 소스 테이블과 복제용 보조 객체에 대한 SELECT 권한이 있는 데이터베이스 사용자를 사용해야 합니다. 변경 데이터 캡처(CDC) 작업의 경우이 사용자에게 REPLICATION CLIENT (BINLOG MONITORMMariaDB 버전 10.5.2 이후) 및 REPLICATION SLAVE 권한도 있어야 합니다. 전체 로드 데이터 마이그레이션의 경우, 이 두 가지 권한이 필요하지 않습니다.

다음 스크립트를 사용하여 내SQL 데이터베이스에 필요한 권한이 있는 데이터베이스 사용자를 생성합니다. 마이그레이션하는 모든 데이터베이스에 대해 GRANT 쿼리를 실행합니다 AWS.

CREATE USER 'your_user'@'%' IDENTIFIED BY 'your_password'; GRANT REPLICATION SLAVE, REPLICATION CLIENT ON *.* TO 'your_user'@'%'; GRANT SELECT, RELOAD, LOCK TABLES, SHOW VIEW, EVENT, TRIGGER ON *.* TO 'your_user'@'%'; GRANT BACKUP_ADMIN ON *.* TO 'your_user'@'%';

앞의 예제에서 각각user input placeholder을 사용자 고유의 정보로 바꿉니다. 소스 내SQL 데이터베이스 버전이 8.0보다 낮으면 GRANT BACKUP_ADMIN 명령을 건너뛸 수 있습니다.

다음 스크립트를 사용하여 MariaDB 데이터베이스에서 필요한 권한을 가진 데이터베이스 사용자를 생성합니다. 마이그레이션하는 모든 데이터베이스에 대해 GRANT 쿼리를 실행합니다 AWS.

CREATE USER 'your_user'@'%' IDENTIFIED BY 'your_password'; GRANT SELECT, RELOAD, LOCK TABLES, REPLICATION SLAVE, BINLOG MONITOR, SHOW VIEW ON *.* TO 'your_user'@'%';

앞의 예제에서 각각user input placeholder을 사용자 고유의 정보로 바꿉니다.

다음 섹션에서는 자체 관리형 및 관리형 AWS내SQL 데이터베이스를 위한 특정 구성 사전 조건을 설명합니다.

자체 관리형 MySQL 호환 데이터베이스를 동종 데이터 마이그레이션의 소스로 사용

이 섹션에서는 온프레미스 또는 Amazon EC2 인스턴스에서 호스팅되는 MySQL 호환 데이터베이스를 구성하는 방법을 설명합니다.

소스 MySQL 또는 MariaDB 데이터베이스의 버전을 확인합니다. 에서에 설명된 대로 소스 MySQL 또는 MariaDB 데이터베이스 버전을 AWS DMS 지원하는지 확인합니다DMS 동종 데이터 마이그레이션을 위한 소스.

를 사용하려면 바이너리 로깅을 활성화해야 CDC합니다. 바이너리 로깅을 활성화하려면 MySQL 또는 MariaDB 데이터베이스의 my.ini (Windows) 또는 my.cnf (UNIX) 파일에서 다음 파라미터를 구성합니다.

파라미터

server-id

이 파라미터 값을 1 이상의 값으로 설정합니다.

log-bin

log-bin=E:\MySql_Logs\BinLog과 같은 이진 로그 파일로 이 경로를 설정합니다. 파일 확장자를 포함해서는 안 됩니다.

binlog_format

이 파라미터를 ROW으로 설정합니다. binlog_formatSTATEMENT로 설정하면 대상에 데이터를 복제할 때 불일치가 발생할 수 있으므로 복제 중에 이 설정을 사용하는 것이 좋습니다. 또한 데이터베이스 엔진이 자동으로 STATEMENT 기반 로깅으로 전환되기 때문에 binlog_formatMIXED로 설정된 경우 데이터베이스 엔진은 일관되지 않은 유사 데이터를 대상에 기록합니다.

expire_logs_days

이 파라미터 값을 1 이상의 값으로 설정합니다. 디스크 공간의 과사용을 방지하려면 기본값 0을 사용하지 않는 것이 좋습니다.

binlog_checksum

이 파라미터를 NONE으로 설정합니다.

binlog_row_image

이 파라미터를 FULL로 설정합니다.

log_slave_updates

MySQL 또는 MariaDB 복제본을 소스로 사용하는 TRUE 경우이 파라미터를 로 설정합니다.

에서 동종 데이터 마이그레이션을 위한 소스로 AWS관리형 내SQL 호환 데이터베이스 사용 AWS DMS

이 섹션에서는 Amazon RDS for MySQL 및 Amazon RDS for MariaDB 데이터베이스 인스턴스를 구성하는 방법을 설명합니다.

AWS관리형 MySQL 또는 MariaDB 데이터베이스를의 동종 데이터 마이그레이션을 위한 소스로 사용하는 경우에 대해 CDC다음과 같은 사전 요구 사항이 있는지 AWS DMS확인합니다.

  • MySQL 및 MariaDB에 대해에 RDS 대한 바이너리 로그를 활성화하려면 인스턴스 수준에서 자동 백업을 활성화합니다. Aurora MySQL 클러스터에 대해 바이너리 로그를 활성화하려면 binlog_format 파라미터 그룹에서 변수를 변경합니다. Aurora MySQL 클러스터에 대해 자동 백업을 활성화할 필요가 없습니다.

    그런 다음, binlog_format 파라미터를 ROW로 설정합니다.

    자동 백업 설정에 대한 자세한 내용은 Amazon RDS 사용 설명서자동 백업 활성화를 참조하세요.

    Amazon RDS for MySQL 또는 MariaDB 데이터베이스의 바이너리 로깅 설정에 대한 자세한 내용은 Amazon RDS 사용 설명서의 바이너리 로깅 형식 설정을 참조하세요.

    Aurora MySQL 클러스터의 바이너리 로깅 설정에 대한 자세한 내용은 Amazon Aurora MySQL 클러스터의 바이너리 로깅을 켜려면 어떻게 해야 하나요?를 참조하세요.

  • 바이너리 로그를 사용할 수 있는지 확인합니다 AWS DMS. AWS관리형 MySQL 및 MariaDB 데이터베이스는 최대한 빨리 바이너리 로그를 제거하므로 로그가 사용 가능한 상태로 유지되는 시간을 늘려야 합니다. 예를 들어, 로그 보존 시간을 24시간으로 늘리려면 다음 명령을 실행합니다.

    call mysql.rds_set_configuration('binlog retention hours', 24);
  • binlog_row_image 파라미터를 Full로 설정합니다.

  • binlog_checksum 파라미터를 NONE으로 설정합니다.

  • Amazon RDS MySQL 또는 MariaDB 복제본을 소스로 사용하는 경우 읽기 전용 복제본에서 백업을 활성화하고 log_slave_updates 파라미터가 로 설정되어 있는지 확인합니다TRUE.

동종 데이터 마이그레이션을 위한 소스로 내SQL 호환 데이터베이스를 사용하는 경우의 제한 사항

동종 데이터 마이그레이션을 위한 소스로 내SQL 호환 데이터베이스를 사용하는 경우 다음 제한이 적용됩니다.

  • 시퀀스와 같은 MariaDB 객체는 동종 마이그레이션 작업에서 지원되지 않습니다.

  • 호환되지 않는 객체 차이로 인해 MariaDB에서 Amazon RDS MySQL/Aurora MySQL로 마이그레이션이 실패할 수 있습니다.

  • 데이터 소스에 연결하는 데 사용하는 사용자 이름에는 다음과 같은 제한이 있습니다.

    • 길이는 2~64자일 수 있습니다.

    • 스페이스를 포함할 수 없습니다.

    • a-z, A-Z, 0-9, 밑줄(_) 문자를 포함할 수 있습니다.

    • a-z 또는 A-Z로 시작해야 합니다.

  • 데이터 소스에 연결하는 데 사용하는 암호에는 다음과 같은 제한이 있습니다.

    • 길이는 1~128자일 수 있습니다.

    • 작은따옴표('), 큰따옴표("), 세미콜론(;) 또는 스페이스는 포함할 수 없습니다.

  • AWS DMS 동종 데이터 마이그레이션은 소스 객체가 암호화된 경우에도 대상 Amazon RDS 인스턴스에 암호화되지 않은 MySQL 및 MariaDB 객체를 생성합니다. RDS for MySQL는 암호화된 객체에 필요한 MySQL keyring_aws AWS Keyring 플러그인을 지원하지 않습니다. Amazon RDS 사용 설명서의 내SQL 키링 플러그인 지원되지 않음 설명서를 참조하세요.