Microsoft SQL Server Always On 가용성 그룹을 사용하면 여러 SQL Server Enterprise 인스턴스에서 데이터베이스를 복제할 수 있습니다.
SQL Server 장애 조치 클러스터 인스턴스와 마찬가지로 Always On 가용성 그룹은 Windows Server 장애 조치 클러스터링 (WSFC)을 사용하여 고가용성을 구현합니다. 그러나 두 기능은 다음과 같은 차이점이 있습니다.
Always On 가용성 그룹 | 클러스터 인스턴스 장애 조치 | |
---|---|---|
장애 조치 범위 | 데이터베이스 그룹 | 인스턴스 |
스토리지 | 비공개 | 공유 |
두 가지를 서로 상세하게 비교한 내용은 장애 조치 클러스터 인스턴스 및 가용성 그룹 비교를 참고하세요.
Always On 가용성 그룹은 여러 가용성 모드를 지원합니다. 이 튜토리얼에서는 데이터베이스 하나 이상에 고가용성을 구현하기 위해 동기식 커밋 모드에서 Always On 가용성 그룹을 배포하는 방법을 설명합니다.
이 설정에서는 VM 인스턴스 3개를 만듭니다. VM 인스턴스 두 개(node-1
및 node-2
)가 클러스터 노드 역할을 하고 SQL Server를 실행합니다.
세 번째 VM 인스턴스(witness
)는 장애 조치 시나리오에서 쿼럼을 확보하는 데 사용됩니다.
VM 인스턴스 3개가 영역 3개에 배포되고 공통 서브넷을 공유합니다.
SQL Server AlwaysOn 가용성 그룹을 사용하면 예시 데이터베이스 bookshelf
가 두 SQL Server 인스턴스에 동기식으로 복제됩니다.
온프레미스 Windows 클러스터 환경에서 주소 확인 프로토콜 (ARP) 알림은 IP 주소 장애 조치를 트리거합니다. 그러나Google Cloud는 ARP 공지사항을 무시합니다. 따라서 내부 부하 분산기와 분산 네트워크 이름 (DNN)을 사용하는 두 가지 옵션 중 하나를 구현해야 합니다.
이 문서에서는 Active Directory를 Google Cloud에 이미 배포했으며 SQL Server, Active Directory, Compute Engine에 대한 기본 지식이 있다고 가정합니다. Google Cloud의 Active Directory에 대한 자세한 내용은 시작하기 전 섹션을 참고하세요.
SQL Server AlwaysOn 가용성 그룹을 사용하면 예시 데이터베이스 bookshelf
가 두 SQL Server 인스턴스에 동기식으로 복제됩니다. 클러스터 앞에 있는 분산 네트워크 이름 (DNN) 리스너는 SQL Server 클라이언트의 단일 엔드포인트를 제공합니다.
DNN에 관한 자세한 내용은 가용성 그룹의 DNN 리스너 구성을 참고하세요.
이 다이어그램에는 다음이 포함됩니다.
- 페일오버 클러스터(
node-1
및node-2
)의 동일한 리전 및 서로 다른 영역에 있는 VM 인스턴스 두 개 하나는 SQL Server 데이터베이스의 기본 복제본을 호스팅하고 다른 노드는 보조 복제본을 호스팅합니다. witness
라는 세 번째 VM은 파일 공유 감시 역할을 하여 동률 처리 기능을 제공하고 장애 조치에 필요한 쿼럼을 확보합니다.- 클러스터 앞에 있는 DNN 리스너는 SQL Server 클라이언트의 단일 엔드포인트를 제공합니다.
목표
- SQL Server VM 인스턴스 2개와 파일 공유 감시 역할을 하는 세 번째 VM 인스턴스로 구성된 WSFC를 배포합니다.
- 동기 커밋으로 가용성 그룹을 만듭니다.
- SQL Server를 사용하여 트래픽을 가용성 그룹으로 라우팅하도록 분산 네트워크 이름 (DNN)을 구성합니다.
- 장애 조치를 시뮬레이션하여 설정이 작동하는지 확인합니다.
비용
이 튜토리얼에서는 다음과 같은 비용이 청구될 수 있는 Google Cloud구성요소를 사용합니다.
가격 계산기를 사용하면 예상 사용량을 기준으로 예상 비용을 산출할 수 있습니다.
시작하기 전에
이 튜토리얼의 태스크를 완료하려면 다음을 확인하세요.
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
- 도메인 컨트롤러가 하나 이상 있는 Active Directory 도메인이 있습니다. 관리형 Microsoft AD를 사용하여 Active Directory 도메인을 만들 수 있습니다. 또는 Compute Engine에 커스텀 Active Directory 환경을 배포하고 DNS 쿼리를 도메인 컨트롤러에 전달하는 비공개 DNS 전달 영역을 설정할 수 있습니다.
-
컴퓨터를 도메인에 조인할 수 있는 권한이 있고 RDP를 사용하여 로그인할 수 있는 Active Directory 사용자가 있습니다. 관리형 Microsoft AD를 사용하는 경우
setupadmin
사용자를 사용할 수 있습니다. Active Directory 사용자 계정 프로비저닝에 관한 자세한 내용은 Active Directory 사용자 계정 프로비저닝을 참고하세요. - Google Cloud 프로젝트 및 Active Directory 도메인 컨트롤러에 연결된 Virtual Private Cloud (VPC)
- Windows Server 장애 조치 클러스터 VM 인스턴스에 사용할 서브넷입니다.
프로젝트 및 네트워크 준비
SQL Server AlwaysOn 가용성 그룹을 배포하려면 배포를 위해Google Cloud 프로젝트와 VPC를 준비해야 합니다. 다음 섹션에서는 이를 수행하는 방법을 자세히 설명합니다.
프로젝트 및 리전 구성
SQL Server AlwaysOn 가용성 그룹을 배포할 수 있도록 Google Cloud 프로젝트를 준비하려면 다음 단계를 따르세요.
Google Cloud 콘솔에서 Cloud Shell 활성화 버튼을 클릭하여 Cloud Shell을 엽니다.
다음 변수를 초기화합니다.
VPC_NAME=
VPC_NAME
SUBNET_NAME=SUBNET_NAME
다음을 바꿉니다.
VPC_NAME
: VPC 이름SUBNET_NAME
: 서브넷 이름
기본 프로젝트 ID를 설정합니다.
gcloud config set project
PROJECT_ID
PROJECT_ID
를 Google Cloud 프로젝트의 ID로 바꿉니다.기본 리전을 설정합니다.
gcloud config set compute/region
REGION
REGION
을 배포하려는 리전의 ID로 바꿉니다.
방화벽 규칙 만들기
클라이언트가 SQL Server에 연결하고 클러스터 노드 간의 통신을 허용하려면 몇 가지 방화벽 규칙을 만들어야 합니다. 다음과 같이 네트워크 태그를 사용하여 이러한 방화벽 규칙을 간단하게 만들 수 있습니다.
- 클러스터 노드 2개는
wsfc-node
태그로 주석 처리됩니다. - 모든 서버 (
witness
포함)는wsfc
태그로 주석 처리됩니다.
이러한 네트워크 태그를 사용하는 방화벽 규칙을 만들려면 다음 단계를 따르세요.
- 기존 Cloud Shell 세션으로 돌아갑니다.
클러스터 노드 간의 트래픽을 허용하는 방화벽 규칙을 만듭니다.
SUBNET_CIDR=$(gcloud compute networks subnets describe $SUBNET_NAME --format=value\('ipCidrRange'\)) gcloud compute firewall-rules create allow-all-between-wsfc-nodes \ --direction=INGRESS \ --action=allow \ --rules=tcp,udp,icmp \ --enable-logging \ --source-tags=wsfc \ --target-tags=wsfc \ --network=$VPC_NAME \ --priority 10000 gcloud compute firewall-rules create allow-sql-to-wsfc-nodes \ --direction=INGRESS \ --action=allow \ --rules=tcp:1433 \ --enable-logging \ --source-ranges=$SUBNET_CIDR \ --target-tags=wsfc-node \ --network=$VPC_NAME \ --priority 10000
VM 인스턴스 만들기
장애 조치 클러스터에 VM 인스턴스 두 개를 만들고 배포합니다. 언제든지 이러한 VM 중 하나가 SQL Server 데이터베이스의 기본 복제본을 호스팅하고 다른 노드는 보조 복제본을 호스팅합니다. 두 VM 인스턴스는 다음 조건을 충족해야 합니다.
- 장애 조치 클러스터링과 SQL Server가 설치되어 있어야 합니다.
- Compute Engine WSFC 지원이 사용 설정되어 있어야 합니다.
SQL Server 2022가 사전 설치된 SQL Server 프리미엄 이미지를 사용합니다.
동률 처리 기능을 제공하고 장애 조치 시나리오에 사용되는 쿼럼을 확보하려면 다음 단계에 따라 파일 공유 감시 역할을 하는 세 번째 VM을 배포합니다.
- 기존 Cloud Shell 세션으로 돌아갑니다.
WSFC 노드의 특수 스크립트를 만듭니다. 이 스크립트는 필요한 Windows 기능을 설치하고 WSFC 및 SQL Server의 방화벽 규칙을 만듭니다.
cat << "EOF" > specialize-node.ps1 $ErrorActionPreference = "stop" # Install required Windows features Install-WindowsFeature Failover-Clustering -IncludeManagementTools Install-WindowsFeature RSAT-AD-PowerShell # Open firewall for WSFC netsh advfirewall firewall add rule name="Allow WSFC health check" dir=in action=allow protocol=TCP localport=59998 # Open firewall for SQL Server netsh advfirewall firewall add rule name="Allow SQL Server" dir=in action=allow protocol=TCP localport=1433 # Open firewall for SQL Server replication netsh advfirewall firewall add rule name="Allow SQL Server replication" dir=in action=allow protocol=TCP localport=5022 # Format data disk Get-Disk | Where partitionstyle -eq 'RAW' | Initialize-Disk -PartitionStyle MBR -PassThru | New-Partition -AssignDriveLetter -UseMaximumSize | Format-Volume -FileSystem NTFS -NewFileSystemLabel 'Data' -Confirm:$false # Create data and log folders for SQL Server md d:\Data md d:\Logs EOF
VM 인스턴스를 만듭니다. 클러스터 노드로 작동하는 두 VM에서 메타데이터 키
enable-wsfc
를true
로 설정하여 추가 데이터 디스크를 연결하고 Windows Server 장애 조치 클러스터링을 사용 설정합니다.REGION=$(gcloud config get-value compute/region) ZONE1=
ZONE1
ZONE2=ZONE2
ZONE3=ZONE3
PD_SIZE=200 MACHINE_TYPE=n2-standard-8 gcloud compute instances create node-1 \ --zone $ZONE1 \ --machine-type $MACHINE_TYPE \ --subnet $SUBNET_NAME \ --image-family sql-ent-2022-win-2022 \ --image-project windows-sql-cloud \ --tags wsfc,wsfc-node \ --boot-disk-size 50 \ --boot-disk-type pd-ssd \ --boot-disk-device-name "node-1" \ --create-disk=name=node-1-datadisk,size=$PD_SIZE,type=pd-ssd,auto-delete=no \ --metadata enable-wsfc=true \ --metadata-from-file=sysprep-specialize-script-ps1=specialize-node.ps1 gcloud compute instances create node-2 \ --zone $ZONE2 \ --machine-type $MACHINE_TYPE \ --subnet $SUBNET_NAME \ --image-family sql-ent-2022-win-2022 \ --image-project windows-sql-cloud \ --tags wsfc,wsfc-node \ --boot-disk-size 50 \ --boot-disk-type pd-ssd \ --boot-disk-device-name "node-2" \ --create-disk=name=node-2-datadisk,size=$PD_SIZE,type=pd-ssd,auto-delete=no \ --metadata enable-wsfc=true \ --metadata-from-file=sysprep-specialize-script-ps1=specialize-node.ps1 gcloud compute instances create "witness" \ --zone $ZONE3 \ --machine-type e2-medium \ --subnet $SUBNET_NAME \ --image-family=windows-2022 \ --image-project=windows-cloud \ --tags wsfc \ --boot-disk-size 50 \ --boot-disk-type pd-ssd \ --metadata sysprep-specialize-script-ps1="add-windowsfeature FS-FileServer"사용 중인 영역을 기반으로 ZONE1, ZONE2, ZONE3을 바꿉니다.
VM 인스턴스 3개를 Active Directory에 조인하려면 VM 인스턴스 3개마다 다음을 수행합니다.
직렬 포트 출력을 확인하여 VM의 초기화 프로세스를 모니터링합니다.
gcloud compute instances tail-serial-port-output
NAME
NAME
을 VM 인스턴스의 이름으로 바꿉니다.출력으로
Instance setup finished
가 표시될 때까지 몇 분 정도 기다린 다음 Ctrl+C를 누릅니다. 이제 VM 인스턴스를 사용할 수 있습니다.VM 인스턴스의 사용자 이름과 비밀번호를 만듭니다.
원격 데스크톱을 사용하여 VM에 연결하고 이전 단계에서 만든 사용자 이름과 비밀번호를 사용하여 로그인합니다.
Start(시작) 버튼을 마우스 오른쪽 버튼으로 클릭하고(또는 Win+X 누름) Windows PowerShell(관리자)을 클릭합니다.
예를 클릭하여 권한 승격 프롬프트를 확인합니다.
컴퓨터를 Active Directory 도메인에 연결하고 다시 시작합니다.
Add-Computer -Domain
DOMAIN -Restart
DOMAIN
을 Active Directory 도메인의 DNS 이름으로 바꿉니다.VM을 도메인에 조인할 수 있는 권한이 있는 계정의 사용자 인증 정보를 입력합니다.
VM이 다시 시작될 때까지 기다립니다. 이제 VM 인스턴스가 Active Directory에 가입되었습니다.
장애 조치 클러스터 배포
이제 VM 인스턴스를 사용하여 Windows Server 장애 조치 클러스터와 SQL Server를 배포할 수 있습니다. 다음 섹션에서는 이를 수행하는 방법을 자세히 설명합니다.
SQL Server 준비
다음 단계에 따라 SQL Server용 Active Directory에 새 사용자 계정을 만듭니다.
- 원격 데스크톱을 사용하여
node-1
에 연결합니다. 도메인 사용자 계정으로 로그인합니다. - Start(시작) 버튼을 마우스 오른쪽 버튼으로 클릭하고(또는 Win+X 누름) Windows PowerShell(관리자)을 클릭합니다.
- 예를 클릭하여 권한 승격 프롬프트를 확인합니다.
SQL 서버와 SQL 에이전트의 도메인 사용자 계정을 만들고 비밀번호를 할당합니다.
$Credential = Get-Credential -UserName sql_server -Message 'Enter password' New-ADUser ` -Name "sql_server" ` -Description "SQL Admin account." ` -AccountPassword $Credential.Password ` -Enabled $true -PasswordNeverExpires $true
SQL Server를 구성하려면 node-1
및 node-2
모두에서 다음 단계를 수행합니다.
- SQL Server 구성 관리자를 엽니다.
- 탐색창에서 SQL Server 서비스를 선택합니다.
- 서비스 목록에서 SQL Server(MSSQLSERVER)를 마우스 오른쪽 버튼으로 클릭하고 속성을 선택합니다.
다음으로 로그온에서 다음과 같이 계정을 변경합니다.
- 계정 이름:
DOMAIN\sql_server
. 여기서DOMAIN
은 Active Directory 도메인의 NetBIOS 이름입니다. - 비밀번호: 이전에 선택한 비밀번호를 입력합니다.
- 계정 이름:
확인을 클릭합니다.
SQL Server를 다시 시작하라는 메시지가 표시되면 예를 선택합니다.
이제 SQL Server가 도메인 사용자 계정으로 실행됩니다.
파일 공유 만들기
VM 인스턴스 witness
에 SQL Server 백업을 저장하고 파일 공유 감시 역할을 할 수 있도록 파일 공유 두 개를 만듭니다.
- 원격 데스크톱을 사용하여
witness
에 연결합니다. 도메인 사용자 계정으로 로그인합니다. - 시작 버튼을 마우스 오른쪽 버튼으로 클릭하고(또는 Win+X 누름) Windows PowerShell(관리자)을 클릭합니다.
- 예를 클릭하여 권한 승격 프롬프트를 확인합니다.
감시 파일 공유를 만들고 자신과 클러스터 노드 두 개에 파일 공유에 대한 액세스 권한을 부여합니다.
New-Item "C:\QWitness" –type directory icacls C:\QWitness\ /grant 'node-1$:(OI)(CI)(M)' icacls C:\QWitness\ /grant 'node-2$:(OI)(CI)(M)' New-SmbShare ` -Name QWitness ` -Path "C:\QWitness" ` -Description "SQL File Share Witness" ` -FullAccess $env:username,node-1$,node-2$
백업을 저장하고 SQL Server에 전체 액세스 권한을 부여하기 위해 다른 파일 공유를 생성합니다.
New-Item "C:\Backup" –type directory New-SmbShare ` -Name Backup ` -Path "C:\Backup" ` -Description "SQL Backup" ` -FullAccess $env:USERDOMAIN\sql_server
장애 조치 클러스터 만들기
페일오버 클러스터를 만들려면 다음 단계를 따르세요.
node-1
의 원격 데스크톱 세션으로 돌아갑니다.- Start(시작) 버튼을 마우스 오른쪽 버튼으로 클릭하고(또는 Win+X 누름) Windows PowerShell(관리자)을 클릭합니다.
- 예를 클릭하여 권한 승격 프롬프트를 확인합니다.
새 클러스터를 만듭니다.
New-Cluster ` -Name sql-cluster ` -Node node-1,node-2 ` -NoStorage ` -ManagementPointNetworkType Distributed
witness
의 PowerShell 세션으로 돌아가 클러스터의 가상 컴퓨터 객체에서 파일 공유에 액세스할 수 있는 권한을 부여합니다.icacls C:\QWitness\ /grant 'sql-cluster$:(OI)(CI)(M)' Grant-SmbShareAccess ` -Name QWitness ` -AccountName 'sql-cluster$' ` -AccessRight Full ` -Force
node-1
의 PowerShell 세션으로 돌아가witness
의 파일 공유를 클러스터 쿼럼으로 사용하도록 클러스터를 구성합니다.Set-ClusterQuorum -FileShareWitness \\witness\QWitness
클러스터가 성공적으로 생성되었는지 확인합니다.
Test-Cluster
다음과 같이 무시할 수 있는 경고가 표시될 수 있습니다.
WARNING: System Configuration - Validate All Drivers Signed: The test reported some warnings.. WARNING: Network - Validate Network Communication: The test reported some warnings.. WARNING: Test Result: HadUnselectedTests, ClusterConditionallyApproved Testing has completed for the tests you selected. You should review the warnings in the Report. A cluster solution is supported by Microsoft only if you run all cluster validation tests, and all tests succeed (with or without warnings).
cluadmin.msc
를 실행하여 장애 조치 클러스터 관리자 MMC 스냅인을 실행하여 클러스터 상태를 검토할 수도 있습니다.관리형 AD를 사용하는 경우 컴퓨터를 도메인에 조인할 수 있도록 Windows 클러스터에서 사용하는 컴퓨터 계정을 Cloud 서비스 도메인 조인 계정 그룹에 추가합니다.
Add-ADGroupMember ` -Identity "Cloud Service Domain Join Accounts" ` -Members sql-cluster$
두 노드에서 Always On 가용성 그룹을 사용 설정합니다.
Enable-SqlAlwaysOn -ServerInstance node-1 -Force Enable-SqlAlwaysOn -ServerInstance node-2 -Force
가용성 그룹 만들기
이제 샘플 데이터베이스 bookshelf
를 만들어 bookshelf-ag
라는 새 가용성 그룹에 포함하고 고가용성을 구성합니다.
데이터베이스 만들기
새 데이터베이스를 만듭니다. 이 튜토리얼에서는 데이터베이스에 데이터가 포함될 필요는 없습니다.
node-1
의 원격 데스크톱 세션으로 돌아갑니다.- SQL Server 관리 스튜디오를 엽니다.
- 서버에 연결 대화상자에서 서버 이름이
node-1
으로 설정되어 있는지 확인하고 연결을 선택합니다. - 메뉴에서 File(파일) > New(새로 만들기) > Query with current connection(현재 연결로 쿼리)을 선택합니다.
다음 SQL 스크립트를 편집기에 붙여넣습니다.
-- Create a sample database CREATE DATABASE bookshelf ON PRIMARY ( NAME = 'bookshelf', FILENAME='d:\Data\bookshelf.mdf', SIZE = 256MB, MAXSIZE = UNLIMITED, FILEGROWTH = 256MB) LOG ON ( NAME = 'bookshelf_log', FILENAME='d:\Logs\bookshelf.ldf', SIZE = 256MB, MAXSIZE = UNLIMITED, FILEGROWTH = 256MB) GO USE [bookshelf] SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON GO -- Create sample table CREATE TABLE [dbo].[Books] ( [Id] [bigint] IDENTITY(1,1) NOT NULL, [Title] [nvarchar](max) NOT NULL, [Author] [nvarchar](max) NULL, [PublishedDate] [datetime] NULL, [ImageUrl] [nvarchar](max) NULL, [Description] [nvarchar](max) NULL, [CreatedById] [nvarchar](max) NULL, CONSTRAINT [PK_dbo.Books] PRIMARY KEY CLUSTERED ([Id] ASC) WITH ( PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY] ) ON [PRIMARY] TEXTIMAGE_ON [PRIMARY] GO -- Create a backup EXEC dbo.sp_changedbowner @loginame = 'sa', @map = false; ALTER DATABASE [bookshelf] SET RECOVERY FULL; GO BACKUP DATABASE bookshelf to disk = '\\witness\Backup\bookshelf.bak' WITH INIT GO
스크립트가 단일 테이블이 있는 새 데이터베이스를 만들고
witness
에 초기 백업을 수행합니다.Execute(실행)를 선택하여 SQL 스크립트를 실행합니다.
고가용성 구성
이제 T-SQL 또는 Server Management Studio를 사용하여 가용성 그룹의 고가용성을 구성할 수 있습니다.
T-SQL 사용
T-SQL을 사용하여 가용성 그룹의 고가용성을 구성하려면 다음 단계를 따르세요.
node-1
에 연결한 다음 다음 스크립트를 실행하여bookshelf-ag
가용성 그룹을 만듭니다.CREATE LOGIN [
NET_DOMAIN
\sql_server] FROM WINDOWS; GO USE [bookshelf]; CREATE USER [NET_DOMAIN
\sql_server] FOR LOGIN [NET_DOMAIN
\sql_server]; GO USE [master]; CREATE ENDPOINT bookshelf_endpoint STATE=STARTED AS TCP (LISTENER_PORT=5022) FOR DATABASE_MIRRORING (ROLE=ALL); GO GRANT CONNECT ON ENDPOINT::[bookshelf_endpoint] TO [NET_DOMAIN
\sql_server] GOnode-2
에 연결하고 다음 스크립트를 실행합니다.CREATE LOGIN [
NET_DOMAIN
\sql_server] FROM WINDOWS; GO CREATE ENDPOINT bookshelf_endpoint STATE=STARTED AS TCP (LISTENER_PORT=5022) FOR DATABASE_MIRRORING (ROLE=ALL); GO GRANT CONNECT ON ENDPOINT::[bookshelf_endpoint] TO [NET_DOMAIN
\sql_server] GOnode-1
에서 다음 스크립트를 실행하여bookshelf-ag
가용성 그룹을 만듭니다.USE master; GO CREATE AVAILABILITY GROUP [bookshelf-ag] WITH (AUTOMATED_BACKUP_PREFERENCE = SECONDARY, CLUSTER_TYPE = WSFC, DB_FAILOVER = ON ) FOR DATABASE [bookshelf] REPLICA ON N'node-1' WITH ( ENDPOINT_URL = 'TCP://node-1:5022', AVAILABILITY_MODE = SYNCHRONOUS_COMMIT, FAILOVER_MODE = AUTOMATIC, BACKUP_PRIORITY = 50, SEEDING_MODE = AUTOMATIC, SECONDARY_ROLE(ALLOW_CONNECTIONS = NO) ), N'node-2' WITH ( ENDPOINT_URL = 'TCP://node-2:5022', AVAILABILITY_MODE = SYNCHRONOUS_COMMIT, FAILOVER_MODE = AUTOMATIC, BACKUP_PRIORITY = 50, SEEDING_MODE = AUTOMATIC, SECONDARY_ROLE(ALLOW_CONNECTIONS = NO) ); GO
node-2
에 연결한 다음 다음 스크립트를 실행하여 보조 복제본을 가용성 그룹에 조인하고 자동 시드를 사용 설정합니다.USE master; GO ALTER AVAILABILITY GROUP [bookshelf-ag] JOIN; ALTER AVAILABILITY GROUP [bookshelf-ag] GRANT CREATE ANY DATABASE;
가용성 그룹의 상태를 확인합니다.
SELECT * FROM sys.dm_hadr_availability_group_states; GO
synchronization_health_desc
가HEALTHY
로 표시됩니다.
SQL Server Management Studio 사용
SQL Server Management Studio를 사용하여 가용성 그룹의 고가용성을 구성하려면 다음 단계를 따르세요.
- 객체 탐색기 창에서 상시 사용 고가용성을 마우스 오른쪽 버튼으로 클릭한 다음 새 가용성 그룹 마법사를 선택합니다.
- 옵션 지정 페이지에서 가용성 그룹 이름을
bookshelf-ag
로 설정한 후 다음을 선택합니다. - 데이터베이스 선택 페이지에서
bookshelf
데이터베이스를 선택한 후 다음을 선택합니다. 복제본 지정 페이지에서 복제본 탭을 선택합니다.
- 복제본 추가를 선택합니다.
서버에 연결 대화상자에서 서버 이름
node-2
를 입력하고 연결을 선택합니다.이제 가용성 복제본 목록에 SQL Server 인스턴스
node-1
및node-2
가 포함됩니다.두 인스턴스 모두에서 가용성 모드를 동기 커밋으로 설정합니다.
두 인스턴스 모두 자동 장애 조치를 사용 설정됨으로 설정합니다.
다음을 선택합니다.
데이터 동기화 선택 페이지에서 자동 시드를 선택합니다.
검증 페이지에서 모든 검사가 성공했는지 확인합니다. 가용성 그룹 리스너 검사는 무시해도 됩니다.
요약 페이지에서 완료를 선택합니다.
결과 페이지에서 닫기를 선택합니다.
가용성 그룹의 DNN 리스너 구성
DNN 리스너는 SQL Server 클라이언트의 단일 엔드포인트 역할을 합니다. DNN 리스너를 구성하려면 다음 단계를 따르세요.
node-1
의 PowerShell 세션으로 돌아갑니다.다음 스크립트를 실행하여 DNN 리스너를 만듭니다.
$Ag='bookshelf-ag' $Port='
DNN_PORT
' $Dns='DNN_NAME
' # create the DNN resource with the port as the resource name Add-ClusterResource -Name $Port -ResourceType "Distributed Network Name" -Group $Ag # set the DNS name of the DNN resource Get-ClusterResource -Name $Port | Set-ClusterParameter -Name DnsName -Value $Dns # start the DNN resource Start-ClusterResource -Name $Port # add the Dependency from availability group resource to the DNN resource Set-ClusterResourceDependency -Resource $Ag -Dependency "[$Port]" # restart the availability group resource Stop-ClusterResource -Name $Ag Start-ClusterResource -Name $AgDNN_PORT
를 DNN 리스너 포트로 바꿉니다. DNN 리스너 포트는 고유한 포트로 구성되어야 합니다. 자세한 내용은 포트 고려사항을 참조하세요.DNN_NAME
을 DNN 리스너 이름으로 바꿉니다.node-1
및node-2
모두에서 DNN 리스너 포트에 대한 방화벽 규칙을 만듭니다.netsh advfirewall firewall add rule name="Allow DNN listener" dir=in action=allow protocol=TCP localport=
DNN_PORT
장애 조치 테스트
이제 장애 조치가 예상대로 작동하는지 테스트할 수 있습니다.
witness
의 PowerShell 세션으로 돌아갑니다.다음 스크립트를 실행합니다.
while ($True){ $Conn = New-Object System.Data.SqlClient.SqlConnection $Conn.ConnectionString = "Server=
DNN_NAME
,DNN_PORT
;Integrated Security=true;Initial Catalog=master" $Conn.Open() $Cmd = New-Object System.Data.SqlClient.SqlCommand $Cmd.Connection = $Conn $Cmd.CommandText = "SELECT SERVERPROPERTY('ServerName')" $Adapter = New-Object System.Data.SqlClient.SqlDataAdapter $Cmd $Data = New-Object System.Data.DataSet $Adapter.Fill($Data) | Out-Null $Data.Tables[0] + (Get-Date -Format "MM/dd/yyyy HH:mm:ss") Start-Sleep -Seconds 2 }DNN_NAME
을 DNN 리스너 이름으로 바꾸고DNN_PORT
을 DNN 리스너 포트로 바꿉니다.스크립트는 2초마다 가용성 그룹 리스너를 사용하여 SQL Server에 연결하고 서버 이름을 쿼리합니다.
스크립트가 실행되도록 둡니다.
node-1
의 원격 데스크톱 세션으로 돌아가서 장애 조치를 트리거합니다.- SQL Server Management Studio에서 상시 사용 고가용성 > 가용성 그룹 > bookshelf-ag(기본)로 이동하고 노드를 마우스 오른쪽 버튼으로 클릭합니다.
- Failover(장애 조치)를 선택합니다.
- 새 기본 복제본 선택 페이지에서
node-2
를 새 기본 복제본으로 선택했는지, 장애 조치 준비 열이No data loss
를 나타내는지 확인합니다. 다음을 선택합니다. - Connect to replica(복제본에 연결) 페이지에서 Connect(연결)를 선택합니다.
- Connect to server(서버에 연결) 대화상자에서 서버 이름이
node-2
인지 확인하고 Connect(연결)를 클릭합니다. - 다음을 선택한 다음 마침을 선택합니다.
- Results(결과) 페이지에서 장애 조치가 성공했는지 확인합니다.
witness
의 PowerShell 세션으로 돌아갑니다.실행 중인 스크립트의 출력을 관찰하고 장애 조치의 결과로 서버 이름이
node-1
에서node-2
로 변경되는 것을 확인합니다.Ctrl+C
를 눌러 스크립트를 중지합니다.
삭제
튜토리얼을 완료한 후에는 만든 리소스를 삭제하여 할당량 사용을 중지하고 요금이 청구되지 않도록 할 수 있습니다. 다음 섹션은 이러한 리소스를 삭제하거나 사용 중지하는 방법을 설명합니다.
프로젝트 삭제
비용이 청구되지 않도록 하는 가장 쉬운 방법은 튜토리얼에서 만든 프로젝트를 삭제하는 것입니다.
프로젝트를 삭제하는 방법은 다음과 같습니다.
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.