Azure 공유 디스크(Azure VM의 SQL Server)를 사용하여 FCI 만들기
적용 대상: Azure VM의 SQL Server
이 문서에서는 Azure VM(Virtual Machines)에서 SQL Server를 사용한 Azure 공유 디스크를 사용하여 FCI(장애 조치(failover) 클러스터 인스턴스)를 만드는 방법을 설명합니다.
자세히 알아보려면 Azure VMs에서 SQL Server를 사용한 FCI 및 클러스터 모범 사례의 개요를 참조하세요.
참고
Azure Migrate를 사용하여 Azure VM의 SQL Server에 대한 장애 조치(failover) 클러스터 인스턴스 솔루션을 리프트 앤 시프트할 수 있습니다. 자세한 내용은 장애 조치(failover) 클러스터 인스턴스 마이그레이션을 참조하세요.
사전 요구 사항
이 문서의 지침을 완료하려면 먼저 다음이 있어야 합니다.
- Azure 구독 무료 Azure 계정으로 시작하세요.
- 가용성 집합 또는 가용성 영역에 준비된 둘 이상의 Azure Windows 가상 머신
- Azure 가상 머신과 Active Directory 모두에서 개체를 만들 수 있는 권한이 있는 계정
- 최신 버전의 Azure PowerShell
팁
SQL Server VM(가상 머신)을 동일한 Azure 가상 네트워크 내의 여러 서브넷에 만들면 배포를 간소화할 수 있고 Azure Load Balancer 또는 DNN(분산 네트워크 이름)을 장애 조치(failover) 클러스터 인스턴스에 사용할 필요가 없습니다.
Azure 공유 디스크 추가
공유 디스크 기능이 사용하도록 설정된 관리형 프리미엄 SSD 디스크를 배포합니다. 모든 FCI 노드에서 디스크를 공유할 수 있도록 클러스터 노드 수와 맞추려면maxShares
를 설정합니다.
VM에 공유 디스크 연결
maxShares > 1을 사용하여 공유 디스크를 배포한 후 클러스터의 노드로 참여할 VM에 디스크를 탑재할 수 있습니다.
공유 디스크를 SQL Server VM에 연결하려면 다음 단계를 수행합니다.
- 공유 디스크를 연결할 Azure Portal에서 VM을 선택합니다.
- 설정 창에서 디스크를 선택합니다.
- 기존 디스크 연결을 선택하여 공유 디스크를 VM에 연결합니다.
- 디스크 이름 드롭다운에서 공유 디스크를 선택합니다.
- 저장을 선택합니다.
- SQL Server VM의 모든 클러스터 노드에 대해 이 단계를 반복합니다.
잠시 후 공유 데이터 디스크가 VM에 연결되고 해당 VM의 데이터 디스크 목록에 나타납니다.
공유 디스크 초기화
공유 디스크가 모든 VM에 연결된 후 클러스터에 노드로 참여할 VM의 디스크를 초기화할 수 있습니다. 모든 VM에서 디스크를 초기화합니다.
SQL Server VM의 디스크를 초기화하려면 다음 단계를 수행합니다.
- VM 중 하나에 연결합니다.
- VM 내부에서 시작 메뉴를 열고 검색 상자에 diskmgmt.msc를 입력하여 디스크 관리 콘솔을 엽니다.
- 디스크 관리에서 초기화되지 않은 새 디스크가 있다고 인식하고 디스크 초기화 창이 나타납니다.
- 새 디스크가 선택되었는지 확인한 후 확인을 선택하여 초기화합니다.
- 새 디스크가 할당되지 않음으로 나타납니다. 디스크의 아무 곳이나 마우스 오른쪽 단추로 클릭하고 새 단순 볼륨을 선택합니다. 새 단순 볼륨 마법사 창이 열립니다.
- 모든 기본값을 유지하여 마법사를 계속 진행하고 완료하면 마침을 선택합니다.
- 디스크 관리를 닫습니다.
- 사용하기 전에 새 디스크를 포맷해야 함을 알리는 팝업 창이 나타납니다. 디스크 포맷을 선택합니다.
- 새 디스크 포맷 창에서 설정을 확인한 후 시작을 선택합니다.
- 디스크를 포맷하면 모든 데이터가 지워짐을 알리는 경고가 나타납니다. 확인을 선택합니다.
- 포맷이 완료되면 확인을 선택합니다.
- FCI에 참여할 각 SQL Server VM에 대해 이러한 단계를 반복합니다.
Windows 장애 조치 클러스터 만들기
Windows Server 장애 조치(failover) 클러스터를 만드는 단계는 단일 서브넷과 다중 서브넷 환경 간에 다릅니다. 클러스터를 만들려면 다중 서브넷 시나리오 또는 단일 서브넷 시나리오에 대한 자습서의 단계를 따릅니다. 이러한 자습서에서는 가용성 그룹을 만들지만 클러스터를 만드는 단계는 장애 조치(failover) 클러스터 인스턴스의 경우와 동일합니다.
쿼럼 구성
디스크 감시는 가장 복원력 있는 쿼럼 옵션이고 FCI 솔루션은 Azure 공유 디스크를 사용하므로 디스크 감시를 쿼럼 솔루션으로 구성하는 것이 좋습니다.
클러스터에 짝수 투표가 있는 경우 비즈니스 요구에 가장 적합한 쿼럼 솔루션을 구성합니다. 자세한 내용은 SQL Server VM에 대한 쿼럼을 참조하세요.
클러스터 유효성 검사
장애 조치 클러스터 관리자 UI 또는 PowerShell을 사용하여 가상 머신 중 하나에서 클러스터의 유효성을 검사합니다.
UI를 사용하여 클러스터의 유효성을 검사하려면 다음 단계를 수행합니다.
- 서버 관리자에서 도구, 장애 조치(Failover) 클러스터 관리자를 차례로 선택합니다.
- 장애 조치(Failover) 클러스터 관리자에서 마우스 오른쪽 단추로 클러스터를 클릭하고, 클러스터 유효성 검사를 선택하여 구성 유효성 검사 마법사를 엽니다.
- 구성 유효성 검사 마법사에서 다음을 선택합니다.
- 서버 또는 클러스터 선택 페이지에서 두 가상 머신의 이름을 입력합니다.
- 테스트 옵션 페이지에서 선택한 테스트만 실행을 선택합니다.
- 다음을 선택합니다.
- 테스트 선택 페이지에서 스토리지를 제외한 모든 테스트를 선택합니다.
- 다음을 선택합니다.
- 확인 페이지에서 다음을 선택합니다. 구성 유효성 검사 마법사가 유효성 검사 테스트를 실행합니다.
PowerShell을 사용하여 클러스터의 유효성을 검사하려면 가상 머신 중 하나의 관리자 PowerShell 세션에서 다음 스크립트를 실행합니다.
Test-Cluster –Node ("<node1>","<node2>") –Include "Inventory", "Network", "System Configuration"
클러스터 장애 조치(failover) 테스트
클러스터의 장애 조치를 테스트합니다. 장애 조치(Failover) 클러스터 관리자에서 클러스터를 마우스 오른쪽 단추로 클릭하고 추가 작업>Move Core Cluster Resource(코어 클러스터 리소스 이동)>노드 선택을 선택한 다음, 클러스터의 다른 노드를 선택합니다. 코어 클러스터 리소스를 클러스터의 모든 노드로 이동한 다음 다시 기본 노드로 이동합니다. SQL Server를 설치하기 전에 클러스터를 각 노드로 성공적으로 이동할 수 있는지 확인합니다.
클러스터에 공유 디스크 추가
장애 조치 클러스터 관리자를 사용하여 연결된 Azure 공유 디스크를 클러스터에 추가합니다.
클러스터에 디스크를 추가하려면 다음 단계를 수행합니다.
서버 관리자 대시보드에서 도구를 선택한 다음, 장애 조치(Failover) 클러스터 관리자를 선택합니다.
탐색 창에서 클러스터를 선택하고 확장합니다.
스토리지를 선택한 다음, 디스크를 선택합니다.
디스크를 마우스 오른쪽 단추로 클릭하고 디스크 추가를 선택합니다.
클러스터 창에 디스크 추가 창에서 Azure 공유 디스크를 선택합니다. 확인을 선택합니다.
공유 디스크가 클러스터에 추가된 후 장애 조치 클러스터 관리자에 표시됩니다.
SQL Server FCI 만들기
장애 조치(failover) 클러스터 및 스토리지를 포함한 모든 클러스터 구성 요소를 구성한 후에는 SQL Server FCI를 만들 수 있습니다.
SQL FCI에서 첫 번째 노드 만들기
SQL Server FCI에서 첫 번째 노드를 만들려면 다음 단계를 수행합니다.
RDP(원격 데스크톱 프로토콜) 또는 Bastion을 사용하여 첫 번째 가상 머신에 연결합니다.
장애 조치(failover) 클러스터 관리자에서 모든 코어 클러스터 리소스가 첫 번째 가상 머신에 있는지 확인합니다. 필요한 경우 디스크를 해당 가상 머신으로 이동합니다.
운영 체제 버전이 Windows Server 2019이고 Windows 클러스터가 기본 분산 네트워크 이름(DNN)을 사용하여 만들어진 경우 SQL Server 2017 이하용 FCI 설치는 오류
The given key was not present in the dictionary
와 함께 실패합니다.설치하는 동안 SQL Server 설치 프로그램은 기존 VNN(가상 네트워크 이름)을 쿼리하고 Windows 클러스터 DNN을 인식하지 못합니다. 이 문제는 SQL Server 2019 설정에서 수정되었습니다. SQL Server 2017 이하의 경우 설치 오류를 방지하려면 다음 단계를 따릅니다.
- 장애 조치(failover) 클러스터 관리자에서 클러스터에 연결하고, 역할을 마우스 오른쪽 단추로 클릭하고 빈 역할 만들기를 선택합니다.
- 새로 만들어진 빈 역할을 마우스 오른쪽 단추로 클릭하고 리소스 추가를 선택한 다음, 클라이언트 액세스 포인트를 선택합니다.
- 이름을 입력하고 마법사를 완료하여 클라이언트 액세스 포인트를 만듭니다.
- SQL Server FCI 설치가 완료된 후 임시 클라이언트 액세스 포인트가 포함된 역할을 삭제할 수 있습니다.
설치 미디어를 찾습니다. 가상 머신이 Azure Marketplace 이미지 중 하나를 사용하는 경우 미디어는
C:\SQLServer_<version number>_Full
에 있습니다.Setup을 선택합니다.
SQL Server 설치 센터에서 설치를 선택합니다.
SQL Server 장애 조치(failover) 클러스터 새로 설치를 선택합니다. 마법사의 지침에 따라 SQL Server FCI를 설치합니다.
클러스터 디스크 선택 페이지에서 VM에 연결된 모든 공유 디스크를 선택합니다.
클러스터 네트워크 구성 페이지에서, 제공하는 IP는 SQL Server VM을 단일 서브넷에 배포했는지 또는 다중 서브넷에 배포했는지에 따라 다릅니다.
- 단일 서브넷 환경의 경우 Azure Load Balancer에 추가할 IP 주소를 제공합니다.
- 다중 서브넷 환경의 경우 이전에 장애 조치 클러스터 인스턴스 네트워크 이름의 IP 주소로 지정한 첫 번째 SQL Server VM의 서브넷에 보조 IP 주소를 제공합니다.
데이터베이스 엔진 구성 페이지에서 데이터베이스 디렉터리가 Azure 공유 디스크에 있는지 확인합니다.
마법사의 지침을 완료하면 SQL Server FCI가 첫 번째 노드에 설치됩니다.
SQL FCI에 추가 노드 추가
추가 노드를 SQL Server FCI에 추가하려면 다음 단계를 수행합니다.
첫 번째 노드에서 FCI 설치가 성공하면 RDP 또는 Bastion을 사용하여 두 번째 노드에 연결합니다.
SQL Server 설치 센터를 연 다음, 설치를 선택합니다.
SQL Server 장애 조치(failover) 클러스터에 노드 추가를 선택합니다. 마법사의 지침에 따라 SQL Server를 설치하고 노드를 FCI에 추가합니다.
다중 서브넷 시나리오의 경우 클러스터 네트워크 구성에서 이전에 장애 조치 클러스터 인스턴스 네트워크 이름의 IP 주소로 지정한 두 번째 SQL Server VM 서브넷에 보조 IP 주소를 입력합니다.
클러스터 네트워크 구성에서 다음을 선택하면 예제 이미지와 같이 SQL Server 설치 프로그램이 여러 서브넷을 검색했음을 나타내는 대화 상자가 표시됩니다. 예를 선택하여 확인합니다.
마법사에서 지침을 완료하면 두 번째 SQL Server FCI 노드가 추가됩니다.
SQL Server 장애 조치 클러스터 인스턴스에 참여하려는 SQL Server VM에서 이러한 단계를 반복합니다.
참고
Azure Marketplace 갤러리 이미지에는 SQL Server Management Studio가 설치되어 제공됩니다. 마켓플레이스 이미지를 사용하지 않은 경우 SSMS(SQL Server Management Studio)를 다운로드합니다.
SQL IaaS 에이전트 익스텐션에 등록
포털에서 SQL Server VM을 관리하려면 SQL IaaS 에이전트 익스텐션에 이를 등록합니다.
참고 항목
현재 SQL IaaS 에이전트 확장에 등록된 Azure 가상 머신의 SQL Server 장애 조치(failover) 클러스터 인스턴스는 자동화된 백업, 패치, Microsoft Entra 인증 및 고급 포털 관리와 같이 에이전트가 필요한 기능이 아니라 기본 등록을 통해 사용할 수 있는 제한된 수의 기능만 지원합니다. 자세한 내용은 혜택 테이블을 참조하세요.
PowerShell을 사용하여 SQL Server VM을 등록합니다(-LicenseType은 PAYG
또는 AHUB
일 수 있음).
# Get the existing compute VM
$vm = Get-AzVM -Name <vm_name> -ResourceGroupName <resource_group_name>
# Register SQL VM with SQL IaaS Agent extension
New-AzSqlVM -Name $vm.Name -ResourceGroupName $vm.ResourceGroupName -Location $vm.Location `
-LicenseType <license_type>
연결 구성
여러 서브넷에 SQL Server VM을 배포한 경우 이 단계를 건너뜁니다. SQL Server VM을 단일 서브넷에 배포한 경우 트래픽을 FCI로 라우팅하도록 추가 구성 요소를 구성해야 합니다. 장애 조치(failover) 클러스터 인스턴스에 대해 Azure Load Balancer가 있는 VNN(가상 네트워크 이름) 또는 분산 네트워크 이름을 구성할 수 있습니다. 두 항목의 차이점을 검토한 다음, 장애 조치 클러스터 인스턴스에 대해 분산 네트워크 이름 또는 가상 네트워크 이름 및 Azure Load Balancer를 배포합니다.
제한 사항
- MSDTC는 Windows Server 2016 이하에서 지원되지 않습니다.
제한된 익스텐션 지원
현재 SQL IaaS 에이전트 확장에 등록된 Azure 가상 머신의 SQL Server 장애 조치(failover) 클러스터 인스턴스는 자동화된 백업, 패치, Microsoft Entra 인증 및 고급 포털 관리와 같이 에이전트가 필요한 기능이 아니라 기본 등록을 통해 사용할 수 있는 제한된 수의 기능만 지원합니다. 자세한 내용은 혜택 테이블을 참조하세요.
SQL Server VM이 SQL IaaS 에이전트 익스텐션에 이미 등록되어 있고 에이전트가 필요한 기능을 사용하도록 설정한 경우 해당 VM에 대한 SQL 가상 머신 리소스를 삭제하여 SQL Server VM에서 익스텐션을 삭제한 다음 SQL IaaS 에이전트 익스텐션에 다시 등록해야 합니다. Azure Portal을 사용하여 SQL 가상 머신 리소스를 삭제할 때 올바른 가상 머신 옆의 확인란을 지워 해당 가상 머신이 삭제되지 않도록 합니다.
다음 단계
Azure 공유 디스크가 적합한 FCI 스토리지 솔루션이 아닌 경우 프리미엄 파일 공유 또는 스토리지 공간 다이렉트를 대신 사용하여 FCI를 만드는 것이 좋습니다.
자세한 내용은 다음을 참조하세요.