분산 AG를 사용하여 독립 실행형 인스턴스에서 데이터베이스 마이그레이션
분산 AG(가용성 그룹)를 사용하여 SQL Server의 독립 실행형 인스턴스에서 Azure VM(Virtual Machines)의 SQL Server로 데이터베이스(또는 여러 데이터베이스)를 마이그레이션합니다.
원본 SQL Server 인스턴스가 필수 구성 요소를 충족하는지 확인한 후 이 문서의 단계를 수행하여 독립 실행형 SQL Server 인스턴스에 가용성 그룹을 만들고 데이터베이스(또는 데이터베이스 그룹)를 Azure의 SQL Server VM으로 마이그레이션합니다.
이 문서는 SQL Server의 독립 실행형 인스턴스에 있는 데이터베이스를 대상으로 합니다. 이 솔루션에는 WSFC(Windows Server 장애 조치(Failover) 클러스터) 또는 가용성 그룹 수신기가 필요하지 않습니다. 가용성 그룹의 데이터베이스를 마이그레이션할 수도 있습니다.
초기 설정
첫 번째 단계는 Azure에서 SQL Server VM을 만드는 것입니다. Azure Portal, Azure PowerShell 또는 ARM 템플릿을 사용하여 해당 작업을 수행할 수 있습니다.
필수 구성 요소에 따라 SQL Server VM을 구성해야 합니다.
간단하게 하기 위해 대상 SQL Server VM을 원본 SQL Server와 동일한 도메인에 조인합니다. 그렇지 않으면 대상 SQL Server VM을 원본 SQL Server의 도메인과 페더레이션된 도메인에 조인합니다.
자동 시드를 사용하여 DAG(분산 가용성 그룹)를 만들려면 DAG의 전역 기본(원본)에 대한 인스턴스 이름은 DAG의 전달자(대상)의 인스턴스 이름과 일치해야 합니다. 전역 기본 및 전달자 간에 인스턴스 이름이 일치하지 않는 경우 수동 시드를 사용하여 DAG를 만들고 향후 추가 데이터베이스 파일을 수동으로 추가해야 합니다.
이 문서에서는 다음 예제 매개 변수를 사용합니다.
- 데이터베이스 이름:
Adventureworks2022
- 원본 머신 이름(DAG의 전역 기본):
OnPremNode
- 원본 SQL Server 인스턴스 이름:
MSSQLSERVER
- 원본 가용성 그룹 이름:
OnPremAg
- 대상 SQL Server VM 이름(DAG의 전달자):
SQLVM
- Azure VM 인스턴스 이름의 대상 SQL Server:
MSSQLSERVER
- 대상 가용성 그룹 이름:
AzureAG
- 엔드포인트 이름:
Hadr_endpoint
- 분산 가용성 그룹 이름:
DAG
- 도메인 이름:
Contoso
엔드포인트 만들기
T-SQL(Transact-SQL)을 사용하여 원본(OnPremNode
) 및 대상(SQLVM
) SQL Server 인스턴스 모두에 엔드포인트를 만듭니다.
엔드포인트를 만들려면 원본 서버와 대상 서버 모두에서 이 T-SQL 스크립트를 실행합니다.
CREATE ENDPOINT [Hadr_endpoint] STATE = STARTED
AS TCP (
LISTENER_PORT = 5022,
LISTENER_IP = ALL
)
FOR DATA_MIRRORING(ROLE = ALL,
AUTHENTICATION = WINDOWS NEGOTIATE,
ENCRYPTION = REQUIRED ALGORITHM AES);
GO
도메인 계정에는 자동으로 엔드포인트에 대한 액세스 권한이 있지만 서비스 계정은 자동으로 sysadmin에 속하지 않으며 연결 권한이 없을 수 있습니다. SQL Server 서비스 계정 연결 권한을 엔드포인트에 수동으로 부여하려면 두 서버 모두에서 다음 T-SQL 스크립트를 실행합니다.
GRANT CONNECT ON ENDPOINT::[Hadr_endpoint] TO [<your account>];
원본 AG 만들기
분산 가용성 그룹은 두 개의 개별 가용성 그룹에 걸쳐 있는 특수 가용성 그룹이기 때문에 먼저 원본 SQL Server 인스턴스에서 가용성 그룹을 만들어야 합니다. Azure에서 유지 관리하고자 하는 가용성 그룹이 이미 있는 경우 대신 가용성 그룹을 마이그레이션합니다.
T-SQL(Transact-SQL)을 사용하여 Adventureworks2022
데이터베이스 예제의 원본 인스턴스(OnPremNode
)에서 가용성 그룹(OnPremAg
)을 만듭니다.
가용성 그룹을 만들려면 원본에서 다음 스크립트를 실행합니다.
CREATE AVAILABILITY GROUP [OnPremAG]
WITH (
AUTOMATED_BACKUP_PREFERENCE = PRIMARY,
DB_FAILOVER = OFF,
DTC_SUPPORT = NONE,
CLUSTER_TYPE = NONE
)
FOR DATABASE [Adventureworks2022] REPLICA ON N'OnPremNode'
WITH (
ENDPOINT_URL = N'TCP://OnPremNode.contoso.com:5022',
FAILOVER_MODE = MANUAL,
AVAILABILITY_MODE = SYNCHRONOUS_COMMIT,
SEEDING_MODE = AUTOMATIC,
SECONDARY_ROLE(ALLOW_CONNECTIONS = NO)
);
GO
대상 AG 만들기
또한 대상 SQL Server VM에도 가용성 그룹을 만들어야 합니다.
T-SQL(Transact-SQL)을 사용하여 대상(AzureAG
) 인스턴스에서 가용성 그룹(SQLVM
)을 만듭니다.
가용성 그룹을 만들려면 대상에서 다음 스크립트를 실행합니다.
CREATE AVAILABILITY GROUP [AzureAG]
WITH (
AUTOMATED_BACKUP_PREFERENCE = PRIMARY,
DB_FAILOVER = OFF,
DTC_SUPPORT = NONE,
CLUSTER_TYPE = NONE,
REQUIRED_SYNCHRONIZED_SECONDARIES_TO_COMMIT = 0
)
FOR REPLICA ON N'SQLVM'
WITH (
ENDPOINT_URL = N'TCP://SQLVM.contoso.com:5022',
FAILOVER_MODE = MANUAL,
AVAILABILITY_MODE = SYNCHRONOUS_COMMIT,
SEEDING_MODE = AUTOMATIC,
SECONDARY_ROLE(ALLOW_CONNECTIONS = NO)
);
GO
분산 AG 만들기
원본(OnPremAG
) 및 대상(AzureAG
) 가용성 그룹을 구성한 후에는 개별 가용성 그룹 모두에 걸쳐 있는 분산 가용성 그룹을 만듭니다.
원본 SQL 인스턴스(OnPremNode
) 및 AG(OnPremAG
)에서 Transact-SQL을 사용하여 분산 가용성 그룹(DAG
)을 만듭니다.
분산 AG를 만들려면 원본에서 다음 스크립트를 실행합니다.
CREATE AVAILABILITY GROUP [DAG]
WITH (DISTRIBUTED) AVAILABILITY GROUP
ON 'OnPremAG' WITH (
LISTENER_URL = 'tcp://OnPremNode.contoso.com:5022',
AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT,
FAILOVER_MODE = MANUAL,
SEEDING_MODE = AUTOMATIC
),
'AzureAG' WITH (
LISTENER_URL = 'tcp://SQLVM.contoso.com:5022',
AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT,
FAILOVER_MODE = MANUAL,
SEEDING_MODE = AUTOMATIC
);
GO
시드 모드는 대상 및 원본의 SQL Server 버전이 동일하므로 AUTOMATIC
로 설정됩니다. SQL Server 대상이 상위 버전이거나 전역 기본 및 전달자의 인스턴스 이름이 다른 경우 분산된 ag를 만들고, SEEDING_MODE
가 MANUAL
로 설정된 분산된 ag에 보조 AG를 조인합니다. 그런 다음, 원본에서 대상 SQL Server 인스턴스로 데이터베이스를 수동으로 복원합니다. 자세한 내용은 마이그레이션 중 버전 업그레이드를 참조하세요.
분산 AG를 만든 후 대상 인스턴스(SQLVM
)에서 대상 AG(AzureAG
)를 분산 AG(DAG
)에 조인합니다.
대상 AG를 분산 AG에 조인하려면 대상에서 다음 스크립트를 실행합니다.
ALTER AVAILABILITY GROUP [DAG]
JOIN AVAILABILITY GROUP
ON 'OnPremAG' WITH (
LISTENER_URL = 'tcp://OnPremNode.contoso.com:5022',
AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT,
FAILOVER_MODE = MANUAL,
SEEDING_MODE = AUTOMATIC
),
'AzureAG' WITH (
LISTENER_URL = 'tcp://SQLVM.contoso.com:5022',
AVAILABILITY_MODE = ASYNCHRONOUS_COMMIT,
FAILOVER_MODE = MANUAL,
SEEDING_MODE = AUTOMATIC
);
GO
원본 및 대상 가용성 그룹 간의 동기화를 취소, 일시 중지 또는 지연해야 하는 경우(예: 성능 문제) 원본 전역 기본 인스턴스(OnPremNode
)에서 다음 스크립트를 실행합니다.
ALTER AVAILABILITY GROUP [DAG]
MODIFY AVAILABILITY GROUP
ON 'AzureAG' WITH (SEEDING_MODE = MANUAL);
자세한 내용은 전달자에 대한 자동 시드 취소를 참조하세요.