프로비저닝된 클러스터를 Amazon Redshift Serverless로 마이그레이션 - Amazon Redshift

프로비저닝된 클러스터를 Amazon Redshift Serverless로 마이그레이션

프로비저닝된 클러스터에서 Amazon Redshift Serverless로 마이그레이션하려면 다음 단계를 참조하세요.

프로비저닝된 클러스터의 스냅샷 생성

프로비저닝된 클러스터에서 Amazon Redshift Serverless로 데이터를 전송하려면 프로비저닝된 클러스터의 스냅샷을 생성한 후 Amazon Redshift Serverless에서 스냅샷을 복원합니다. Amazon Redshift는 프로비저닝된 클러스터 스냅샷을 서버리스 네임스페이스로 복원할 때 인터리브된 키를 복합 키로 자동 변환합니다.

참고

데이터를 서버리스 작업 그룹으로 마이그레이션하기 전에, 프로비저닝된 클러스터 요구 사항이 Amazon Redshift Serverless에서 선택한 RPU 양과 호환되는지 확인하세요.

프로비저닝된 클러스터의 스냅샷을 생성하려면

  1. AWS Management Console에 로그인한 후 https://console.aws.amazon.com/redshiftv2/에서 Amazon Redshift 콘솔을 엽니다.

  2. 탐색 메뉴에서 Clusters(클러스터), Snapshots(스냅샷)을 선택한 다음 Create snapshot(스냅샷 생성)을 선택합니다.

  3. 스냅샷 정의의 속성을 입력한 후 스냅샷 생성을 선택합니다. 스냅샷을 사용할 수 있을 때까지 시간이 다소 걸릴 수 있습니다.

프로비저닝된 클러스터 스냅샷을 서버리스 네임스페이스로 복원

  1. AWS Management Console에 로그인한 후 https://console.aws.amazon.com/redshiftv2/에서 Amazon Redshift 콘솔을 엽니다.

  2. Amazon Redshift 프로비저닝된 클러스터 콘솔에서 시작하여 Clusters(클러스터), Snapshots(스냅샷) 페이지로 이동합니다.

  3. 사용할 스냅샷을 선택합니다.

  4. Restore snapshot(스냅샷 복원), Restore to serverless namespace(서버리스 네임스페이스로 복원)을 선택합니다.

  5. 스냅샷을 어느 네임스페이스로 복원할지 선택합니다.

  6. 스냅샷에서 복원할 것인지 확인합니다. 이 작업은 서버리스 엔드포인트의 모든 데이터베이스를 프로비저닝된 클러스터의 데이터로 바꿉니다. 복원을 선택합니다.

프로비저닝된 클러스터 스냅샷에 대한 자세한 내용은 Amazon Redshift 스냅샷을 참조하세요.

드라이버를 사용하여 Amazon Redshift Serverless에 연결

원하는 SQL 클라이언트에 Amazon Redshift Serverless를 연결하려면, Amazon Redshift에서 제공하는 JDBC 드라이버 버전 2 드라이버를 사용하면 됩니다. JDBC 드라이버 버전 2.1.x 이상을 사용하여 연결하는 것이 좋습니다. 포트 번호는 선택에 따릅니다. 이 드라이버를 포함하지 않으면 Amazon Redshift Serverless는 기본적으로 포트 번호 5439로 설정됩니다. 포트 범위 5431~5455 또는 8191~8215에서 다른 포트로 변경할 수 있습니다. 서버리스 엔드포인트의 기본 포트를 변경하려면 AWS CLI 및 Amazon Redshift API를 사용하세요.

JDBC, ODBC 또는 Python 드라이버에 사용할 정확한 엔드포인트를 찾으려면 Amazon Redshift Serverless에서 작업 그룹 구성을 참조하세요. Amazon Redshift Serverless API 작업인 GetWorkgroup 또는 AWS CLI 작업인 get-workgroups를 사용하여 작업 그룹에 대한 정보를 반환한 다음 연결할 수도 있습니다.

암호 기반 인증을 사용하여 연결

암호 기반 인증을 사용하여 연결하려면 다음 구문을 사용합니다.

jdbc:redshift://<workgroup-name>.<account-number>.<aws-region>.redshift-serverless.amazonaws.com:5439/?username=enter a username&password=enter a password

Amazon Redshift Python 드라이버를 사용하여 연결하려면 다음 구문을 사용합니다.

import redshift_connector with redshift_connector.connect( host='<workgroup-name>.<account-number>.<aws-region>.redshift-serverless.amazonaws.com', database='<database-name>', user='enter a user', password='enter a password' # port value of 5439 is specified by default ) as conn: pass

IAM을 사용하여 연결

IAM을 사용하여 로그인하려면 다음 드라이버 엔드포인트를 사용합니다. 이 드라이버 엔드포인트를 사용하면 특정 데이터베이스에 연결하고 Amazon Redshift Serverless GetCredentials API 작업을 사용할 수 있습니다.

jdbc:redshift:iam://<workgroup-name>.<account-number>.<aws-region>.redshift-serverless.amazonaws.com:5439/<database-name>

이 드라이버 엔드포인트는 dbUser, dbGroupauto-create의 사용자 지정을 지원하지 않습니다. 기본적으로 이 드라이버는 로그인 시 데이터베이스 사용자를 자동으로 생성하고 IAM에서 정의한 그룹에 따라 그룹에 할당합니다. 참고: IAM에서 지정한 그룹 이름에는 소문자, 숫자, 밑줄('_'), 더하기 기호('+'), 마침표(점), at 기호(@) 또는 하이픈('-')만 사용해야 합니다. 그렇지 않으면 드라이버가 dbGroup에 연결되지 않을 수 있습니다.

AWS 자격 증명에 RedshiftServerlessGetCredentials 작업에 대한 올바른 IAM 정책이 있어야 합니다. 다음은 Amazon Redshift Serverless에 연결하기 위한 올바른 권한을 AWS 자격 증명에 부여하는 IAM 정책의 예입니다. IAM 권한에 대한 자세한 내용은 IAM 자격 증명 권한 추가를 참조하세요.

{ "Version": "2012-10-17", "Statement": [ { "Sid": "", "Effect": "Allow", "Action": "redshift-serverless:GetCredentials", "Resource": "*" } ] }

IAM을 사용하여 dbUser 및 dbGroups에 연결

사용자 지정 dbUser 및 dbGroups 연결 옵션을 사용하려면 다음 드라이버 엔드포인트를 사용합니다. 다른 Amazon Redshift Serverless 드라이버 엔드포인트와 마찬가지로 이 구문은 로그인 시에 데이터베이스 사용자를 자동으로 생성합니다. 이 드라이버 엔드포인트는 Amazon Redshift Serverless GetCredentials API 작업을 사용합니다. dbUser는 글자로 시작해야 하고, 영숫자, 밑줄('_'), 더하기 기호('+'), 마침표('.'), at 기호('@') 또는 하이픈('-')만 사용할 수 있으며, 길이는 128자 미만이어야 합니다. dbGroups에는 소문자, 숫자, 밑줄('_'), 더하기 기호('+'), 마침표('.'), at 기호(@) 또는 하이픈만 사용해야 합니다.

jdbc:redshift:iam://redshift-serverless-<workgroup-name>:<aws-region>/<database-name>

Amazon Redshift Python 드라이버를 사용하여 연결하려면 다음 구문을 사용합니다.

import redshift_connector with redshift_connector.connect( iam=True, host='<workgroup-name>.<account-number>.<aws-region>.redshift-serverless.amazonaws.com', database='<database-name>', db_user='enter a user', password='enter a password', db_groups='<db-groups>' # port value of 5439 is specified by default ) as conn: pass

ODBC를 사용하여 연결

ODBC를 사용하여 연결하려면 다음 구문을 사용합니다.

Driver={Amazon Redshift (x64)}; Server=<workgroup-name>.<account-number>.<aws-region>.redshift-serverless.amazonaws.com; Database=dev

Amazon Redshift Serverless SDK 사용

Amazon Redshift SDK를 사용하여 관리 스크립트를 작성한 경우 새로운 Amazon Redshift Serverless SDK를 사용하여 Amazon Redshift Serverless 및 관련 리소스를 관리해야 합니다. 사용 가능한 API 작업에 대한 자세한 내용은 Amazon Redshift Serverless API 참조 가이드를 참조하세요.