관리 지점에 대한 데이터베이스 복제 구성
적용 대상: System Center 2012 Configuration Manager, System Center 2012 Configuration Manager SP1, System Center 2012 Configuration Manager SP2, System Center 2012 R2 Configuration Manager, System Center 2012 R2 Configuration Manager SP1
기본 사이트의 System Center 2012 Configuration Manager 관리 지점이 사이트 데이터베이스의 복제본을 사용하도록 구성할 수 있습니다. 보조 사이트의 관리 지점에서는 데이터베이스 복제본을 지원하지 않습니다.
각 기본 사이트에서 SQL Server를 실행하는 하나 이상의 컴퓨터가 데이터베이스 복제본을 호스팅하도록 구성할 수 있습니다. 그러면 사이트에 있는 둘 이상의 관리 지점에서 동일한 데이터베이스 복제본을 사용할 수 있습니다. 관리 지점에서 데이터베이스 복제본을 사용하는 경우 데이터베이스 복제본을 호스팅하는 SQL Server 컴퓨터로부터 데이터를 요청합니다. 사이트 데이터베이스 서버에 대한 직접 요청 대신 데이터베이스 복제본 서버에 대해 요청이 이루어지므로 클라이언트 정책을 빈번하게 요청하는 클라이언트가 많을 경우에 사이트 데이터베이스 서버에서 CPU 처리 요구 사항을 줄일 수 있습니다.
데이터베이스 복제본을 사용하는 경우 사이트 데이터베이스 서버와 각 데이터베이스 복제본 서버를 정기적으로 모니터링하여 이들 사이에 복제가 이루어지는지 ,그리고 데이터베이스 복제본 서버의 성능이 필요한 사이트 및 클라이언트 성능으로 충분한지 확인합니다.
다음 섹션의 정보는 데이터베이스 복제본을 구성하고 관리하는 데 도움이 됩니다.
데이터베이스 복제본을 사용하도록 구성
데이터베이스 복제본 사용을 위한 작업
데이터베이스 복제본 제거
사이트 서버 제거
사이트 서버 데이터베이스 이동
데이터베이스 복제본을 사용하도록 구성
데이터베이스 복제본을 사용하려면 다음 구성이 모두 필요합니다.
사이트 데이터베이스 서버와 데이터베이스 복제본 서버의 SQL Server에 SQL Server 복제가 설치되어 있어야 합니다.
사이트 데이터베이스에서 데이터베이스 복제본을 게시해야 합니다.
데이터베이스 복제를 호스팅하는 각 원격 SQL Server 컴퓨터에서 게시된 데이터베이스 복제본을 구독해야 합니다.
데이터베이스 복제본을 사용하는 각 관리 지점이 데이터베이스 복제본 서버 및 데이터베이스 복제본과 통신하도록 구성해야 합니다.
데이터베이스 복제본 서버와 통신하는 원격 컴퓨터에서 사용할 관리 지점에 대한 자체 서명된 인증서가 데이터베이스 복제본을 호스팅하는 각 SQL Server 컴퓨터에 있어야 합니다.
사이트 데이터베이스에 사용하는 SQL Server와 각 데이터베이스 복제본이 최대 텍스트 복제 크기(2GB)를 지원하도록 구성해야 합니다. SQL Server 2012에 대해 이를 구성하는 방법의 예는 최대 텍스트 복제 크기 서버 구성 옵션 구성을 참조하세요.
데이터베이스 복제본을 구성하려면 다음 섹션의 절차를 완료해야 합니다.
데이터베이스 복제본을 게시하도록 사이트 데이터베이스 서버 구성
데이터베이스 복제본 서버 구성
관리 지점에서 데이터베이스 복제본을 사용하도록 구성
데이터베이스 복제본 서버에 대한 자체 서명된 인증서 구성
Configuration Manager SP1부터는 다음 섹션의 절차도 완료해야 합니다.
- 데이터베이스 복제본 서버에 대해 SQL Server Service Broker 구성
데이터베이스 복제본을 게시하도록 사이트 데이터베이스 서버 구성
다음 절차는 Windows Server 2008 R2 컴퓨터에서 데이터베이스 복제본을 게시하도록 사이트 데이터베이스 서버를 구성하는 방법의 예입니다. 다른 운영 체제 버전을 사용하는 경우 해당 운영 체제 문서를 참조하여 필요한 대로 이 절차의 단계를 조정합니다.
사이트 데이터베이스 서버를 구성하려면
-
사이트 데이터베이스 서버에서 SQL Server 에이전트가 자동으로 시작되도록 설정합니다.
-
사이트 데이터베이스 서버에서 ConfigMgr_MPReplicaAccess라는 이름의 로컬 사용자 그룹을 만듭니다. 데이터베이스 복제본 서버가 게시된 데이터베이스 복제본과 동기화될 수 있도록 이 사이트에서 사용하는 각 데이터베이스 복제본 서버의 컴퓨터 계정을 이 그룹에 추가해야 합니다.
-
사이트 데이터베이스 서버에서 ConfigMgr_MPReplica라는 이름의 파일 공유를 구성합니다.
-
ConfigMgr_MPReplica 공유에 다음 사용 권한을 추가합니다.
참고
SQL Server 에이전트에서 로컬 시스템 계정이 아닌 계정을 사용하는 경우 다음 목록에서 SYSTEM을 해당 계정 이름으로 대체합니다.
- **공유 사용 권한**: - SYSTEM: **쓰기** - ConfigMgr\_MPReplicaAccess: **읽기**
- **NTFS 사용 권한**: - SYSTEM: **모든 권한** - ConfigMgr\_MPReplicaAccess: **읽기**, **읽기 및 실행**, **폴더 콘텐츠 나열**
-
SQL Server Management Studio를 사용하여 사이트 데이터베이스에 연결하고 spCreateMPReplicaPublication 저장 프로시저를 쿼리로 실행합니다.
저장 프로시저가 완료되면 사이트 데이터베이스 서버가 데이터베이스 복제본을 게시하도록 구성됩니다.
데이터베이스 복제본 서버 구성
데이터베이스 복제본 서버는 SQL Server를 실행하고 관리 지점이 사용할 사이트 데이터베이스의 복제본을 호스팅하는 컴퓨터입니다. 데이터베이스 복제본 서버는 고정된 일정으로 사이트 데이터베이스 서버에서 게시되는 데이터베이스 복제본과 데이터베이스 복제본을 동기화합니다.
데이터베이스 복제본 서버는 사이트 데이터베이스 서버와 동일한 요구 사항을 충족해야 합니다. 그러나 데이터베이스 복제본 서버는 사이트 데이터베이스 서버가 사용하는 것과 다른 에디션 또는 버전의 SQL Server를 실행할 수 있습니다. 지원되는 버전의 SQL Server에 대한 자세한 내용은 항목에서 섹션을 참조하세요.No text is shown for link 'c1e93ef9-761f-4f60-8372-df9bf5009be0'. The title of the linked topic might be empty.c1e93ef9-761f-4f60-8372-df9bf5009be0#BKMK_SupConfigSQLDBconfig
중요 |
---|
복제본 데이터베이스를 호스팅하는 컴퓨터의 SQL Server Service는 System 계정으로 실행해야 합니다. |
다음 절차는 Windows Server 2008 R2 컴퓨터에서 데이터베이스 복제본 서버를 구성하는 방법의 예입니다. 다른 운영 체제 버전을 사용하는 경우 해당 운영 체제 문서를 참조하여 필요한 대로 이 절차의 단계를 조정합니다.
데이터베이스 복제본 서버를 구성하려면
-
데이터베이스 복제본 서버에서 SQL Server 에이전트가 자동으로 시작되도록 설정합니다.
-
데이터베이스 복제본 서버에서 SQL Server Management Studio를 사용하여 로컬 서버에 연결하고 복제 폴더를 찾아 로컬 구독을 클릭하고 새 구독을 선택하여 새 구독 마법사를 시작합니다.
게시 페이지의 게시자 목록 상자에서 SQL Server 게시자 찾기를 선택하고 사이트 데이터베이스 서버의 이름을 입력한 후에 연결을 클릭합니다.
ConfigMgr_MPReplica를 선택한 후에 다음을 클릭합니다.
배포 에이전트 위치 페이지에서 각 에이전트를 해당 구독자(끌어오기 구독)에서 실행을 선택하고 다음을 클릭합니다.
구독자 페이지에서 다음 중 하나를 수행합니다.
데이터베이스 복제본 서버에서 데이터베이스 복제본을 위해 사용할 기존 데이터베이스를 선택하고 확인을 클릭합니다.
새 데이터베이스를 선택하여 데이터베이스 복제본을 위한 새 데이터베이스를 만듭니다.새 데이터베이스 페이지에서 데이터베이스 이름을 지정한 후에 확인을 클릭합니다.
다음을 클릭하여 계속합니다.
배포 에이전트 보안 페이지에서 대화 상자의 구독자 연결 열에 있는 속성 단추 **(.…)**를 클릭하고 연결에 대한 보안 설정을 구성합니다.
팁 속성 단추 (….)는 표시 상자의 네 번째 열에 있습니다.
보안 설정:
배포 에이전트 프로세스를 실행하는 계정(프로세스 계정)을 구성합니다.
SQL Server 에이전트가 로컬 시스템으로 실행되는 경우 **SQL Server 에이전트 서비스 계정으로 실행(최상의 권장 보안 방법은 아님)**을 선택합니다.
SQL Server 에이전트가 다른 계정을 사용하여 실행되는 경우 다음 Windows 계정으로 실행을 선택하고 해당 계정을 구성합니다. Windows 계정 또는 SQL Server 계정을 지정할 수 있습니다.
중요 배포 에이전트 권한을 실행하는 계정을 끌어오기 구독으로 게시자에 할당해야 합니다. 이러한 권한을 구성하는 방법에 대한 자세한 내용은 SQL Server TechNet 라이브러리의 배포 에이전트 보안을 참조하세요.
배포자에 연결에 프로세스 계정 가장을 선택합니다.
구독자에 연결에 프로세스 계정 가장을 선택합니다.
연결 보안 설정을 구성한 후에는 확인을 클릭하여 저장하고 다음을 클릭합니다.
동기화 일정 페이지의 에이전트 일정 목록 상자에서 일정 정의를 선택하고 새 작업 일정을 구성합니다. 주기를 일별, 되풀이 간격을 5분으로 설정하고 기간을 종료 날짜가 없습니다로 설정합니다.다음을 클릭하여 일정을 저장하고 다시 다음을 클릭합니다.
마법사 동작 페이지에서 구독 만들기 확인란을 선택하고 다음을 클릭합니다.
마법사 완료 페이지에서 마침을 클릭하고 닫기를 클릭하여 마법사를 완료합니다.
-
동기화 상태를 검토하여 구독이 성공적인지 확인합니다.
- 구독자 컴퓨터에서: - **SQL Server Management Studio**에서 데이터베이스 복제본 서버에 연결하고 **복제**를 확장합니다. - **로컬 구독**을 확장하고 사이트 데이터베이스 게시에 대한 구독을 마우스 오른쪽 단추로 클릭한 후에 **동기화 상태 보기**를 선택합니다. - 게시자 컴퓨터에서: - **SQL Server Management Studio**에서 사이트 데이터베이스 컴퓨터에 연결하고 **복제** 폴더를 마우스 오른쪽 단추로 클릭한 후에 **복제 모니터 시작**을 선택합니다.
-
데이터베이스 복제본을 위한 CLR(공용 언어 런타임) 통합을 사용하도록 설정하려면 SQL Server Management Studio를 사용하여 데이터베이스 복제본 서버의 데이터베이스 복제본에 연결하고 exec sp_configure 'clr enabled', 1; RECONFIGURE WITH OVERRIDE 저장 프로시저를 쿼리로 실행합니다.
-
데이터베이스 복제본 서버를 사용하는 각 관리 지점에 대해 해당 관리 지점 컴퓨터 계정을 데이터베이스 복제본 서버의 로컬 Administrators 그룹에 추가합니다.
팁 데이터베이스 복제본 서버에서 실행되는 관리 지점의 경우 이 단계가 필요 없습니다.
이제 데이터베이스 복제본을 관리 지점에 사용할 수 있습니다.
관리 지점에서 데이터베이스 복제본을 사용하도록 구성
관리 지점 역할을 설치할 때 기본 사이트의 관리 지점이 데이터베이스 복제본을 사용하도록 구성하거나 기존 관리 지점이 데이터베이스 복제본을 사용하도록 구성할 수 있습니다.
관리 지점에서 데이터베이스 복제본을 사용하도록 구성하려면 다음 정보를 참고하세요.
새 관리 지점을 구성하려면 관리 지점을 설치하기 위해 사용하는 마법사의 관리 지점 데이터베이스 페이지에서 데이터베이스 복제본 사용을 선택하고 데이터베이스 복제본을 호스트하는 컴퓨터의 FQDN을 지정합니다. 그런 다음, 컴퓨터에 있는 데이터베이스 복제본의 데이터베이스 이름을 ConfigMgr 사이트 데이터베이스 이름에 지정합니다.
이전에 설치된 관리 지점을 구성하려면: 관리 지점의 속성 페이지를 열고 관리 지점 데이터베이스 탭에서 데이터베이스 복제본 사용을 선택한 후에 데이터베이스 복제본을 호스팅하는 컴퓨터의 FQDN을 지정합니다. 그런 다음, 컴퓨터에 있는 데이터베이스 복제본의 데이터베이스 이름을 ConfigMgr 사이트 데이터베이스 이름에 지정합니다.
데이터베이스 복제본을 사용하는 각 관리 지점에 대해 관리 지점 서버의 컴퓨터 계정을 데이터베이스 복제본의 db_datareader 역할에 수동으로 추가해야 합니다.
관리 지점에서 데이터베이스 복제본 서버를 사용하도록 구성하는 것 외에도 관리 지점에 대해 IIS에서 Windows 인증을 사용하도록 설정해야 합니다.
IIS(인터넷 정보 서비스) 관리자를 엽니다.
관리 지점에서 사용하는 웹 사이트를 선택하고 인증을 엽니다.
Windows 인증을 사용으로 설정하고 IIS(인터넷 정보 서비스) 관리자를 닫습니다.
데이터베이스 복제본 서버에 대한 자체 서명된 인증서 구성
데이터베이스 복제본 서버에 자체 서명된 인증서를 만들고 데이터베이스 복제본 서버를 사용하는 각 관리 지점에서 이 인증서를 사용할 수 있게 해야 합니다.
데이터베이스 복제본 서버에 설치되는 관리 지점에서는 자동으로 인증서를 사용할 수 있습니다. 그러나 이 인증서를 원격 관리 지점에서 사용할 수 있게 하려면 인증서를 내보낸 다음 원격 관리 지점의 신뢰할 수 있는 사용자 인증서 저장소에 추가해야 합니다.
다음 절차는 Windows Server 2008 R2 컴퓨터에서 데이터베이스 복제본 서버에 자체 서명된 인증서를 구성하는 방법의 예입니다. 다른 운영 체제 버전을 사용하는 경우 해당 운영 체제 문서를 참조하여 필요한 대로 이러한 절차의 단계를 조정합니다.
데이터베이스 복제본 서버에 자체 서명된 인증서를 구성하려면
-
데이터베이스 복제본 서버에서 관리자 권한으로 PowerShell 명령 프롬프트를 열고 set-executionpolicy UnRestricted 명령을 실행합니다.
-
다음 PowerShell 스크립트를 복사하여 CreateMPReplicaCert.ps1이라는 이름의 파일로 저장합니다. 이 파일의 복사본을 데이터베이스 복제본 서버의 시스템 파티션에 있는 루트 폴더에 넣습니다.
# Script for creating a self-signed certificate for the local machine and configuring SQL Server to use it. Param($SQLInstance) $ConfigMgrCertFriendlyName = \"ConfigMgr SQL Server Identification Certificate\" # Get local computer name $computerName = \"$env:computername\" # Get the sql server name #$key=\"HKLM:\SOFTWARE\Microsoft\SMS\MP\" #$value=\"SQL Server Name\" #$sqlServerName= (Get-ItemProperty $key).$value #$dbValue=\"Database Name\" #$sqlInstance_DB_Name= (Get-ItemProperty $key).$dbValue $sqlServerName = [System.Net.Dns]::GetHostByName(\"localhost\").HostName $sqlInstanceName = \"MSSQLSERVER\" $SQLServiceName = \"MSSQLSERVER\" if ($SQLInstance -ne $Null) { $sqlInstanceName = $SQLInstance $SQLServiceName = \"MSSQL$\" + $SQLInstance } # Delete existing cert if one exists function Get-Certificate($storename, $storelocation) { $store=new-object System.Security.Cryptography.X509Certificates.X509Store($storename,$storelocation) $store.Open([Security.Cryptography.X509Certificates.OpenFlags]::ReadWrite) $store.Certificates } $cert = Get-Certificate \"My\" \"LocalMachine\" | ?{$_.FriendlyName -eq $ConfigMgrCertFriendlyName} if($cert -is [Object]) { $store = new-object System.Security.Cryptography.X509Certificates.X509Store(\"My\",\"LocalMachine\") $store.Open([Security.Cryptography.X509Certificates.OpenFlags]::ReadWrite) $store.Remove($cert) $store.Close() # Remove this cert from Trusted People too... $store = new-object System.Security.Cryptography.X509Certificates.X509Store(\"TrustedPeople\",\"LocalMachine\") $store.Open([Security.Cryptography.X509Certificates.OpenFlags]::ReadWrite) $store.Remove($cert) $store.Close() } # Create the new cert $name = new-object -com \"X509Enrollment.CX500DistinguishedName.1\" $name.Encode(\"CN=\" + $sqlServerName, 0) $key = new-object -com \"X509Enrollment.CX509PrivateKey.1\" $key.ProviderName = \"Microsoft RSA SChannel Cryptographic Provider\" $key.KeySpec = 1 $key.Length = 1024 $key.SecurityDescriptor = \"D:PAI(A;;0xd01f01ff;;;SY)(A;;0xd01f01ff;;;BA)(A;;0x80120089;;;NS)\" $key.MachineContext = 1 $key.Create() $serverauthoid = new-object -com \"X509Enrollment.CObjectId.1\" $serverauthoid.InitializeFromValue(\"1.3.6.1.5.5.7.3.1\") $ekuoids = new-object -com \"X509Enrollment.CObjectIds.1\" $ekuoids.add($serverauthoid) $ekuext = new-object -com \"X509Enrollment.CX509ExtensionEnhancedKeyUsage.1\" $ekuext.InitializeEncode($ekuoids) $cert = new-object -com \"X509Enrollment.CX509CertificateRequestCertificate.1\" $cert.InitializeFromPrivateKey(2, $key, \"\") $cert.Subject = $name $cert.Issuer = $cert.Subject $cert.NotBefore = get-date $cert.NotAfter = $cert.NotBefore.AddDays(3650) $cert.X509Extensions.Add($ekuext) $cert.Encode() $enrollment = new-object -com \"X509Enrollment.CX509Enrollment.1\" $enrollment.InitializeFromRequest($cert) $enrollment.CertificateFriendlyName = \"ConfigMgr SQL Server Identification Certificate\" $certdata = $enrollment.CreateRequest(0x1) $enrollment.InstallResponse(0x2, $certdata, 0x1, \"\") # Add this cert to the trusted peoples store [Byte[]]$bytes = [System.Convert]::FromBase64String($certdata) $trustedPeople = new-object System.Security.Cryptography.X509certificates.X509Store \"TrustedPeople\", \"LocalMachine\" $trustedPeople.Open([Security.Cryptography.X509Certificates.OpenFlags]::ReadWrite) $trustedPeople.Add([Security.Cryptography.X509Certificates.X509Certificate2]$bytes) $trustedPeople.Close() # Get thumbprint from cert $sha = new-object System.Security.Cryptography.SHA1CryptoServiceProvider $certHash = $sha.ComputeHash($bytes) $certHashCharArray = \"\"; $certThumbprint = \"\"; # Format the bytes into a hexadecimal string foreach($byte in $certHash) { $temp = ($byte | % {\"{0:x}\" -f $_}) -join \"\" $temp = ($temp | % {\"{0,2}\" -f $_}) $certHashCharArray = $certHashCharArray+ $temp; } $certHashCharArray = $certHashCharArray.Replace(' ', '0'); # SQL needs the thumbprint in lower case foreach($char in $certHashCharArray) { [System.String]$myString = $char; $certThumbprint = $certThumbprint + $myString.ToLower(); } # Configure SQL to use this cert $path = \"HKLM:\SOFTWARE\Microsoft\Microsoft SQL Server\Instance Names\SQL\" $subKey = (Get-ItemProperty $path).$sqlInstanceName $realPath = \"HKLM:\SOFTWARE\Microsoft\Microsoft SQL Server\\" + $subKey + \"\MSSQLServer\SuperSocketNetLib\" $certKeyName = \"Certificate\" Set-ItemProperty -path $realPath -name $certKeyName -Type string -Value $certThumbprint # restart sql service Restart-Service $SQLServiceName -Force
-
데이터베이스 복제본 서버에서 해당 SQL Server 구성에 적용되는 명령을 실행합니다.
- SQL Server의 기본 인스턴스: **CreateMPReplicaCert.ps1** 파일을 마우스 오른쪽 단추로 클릭하고 **PowerShell에서 실행**을 선택합니다. 스크립트가 실행되면 자체 서명된 인증서가 만들어지고 SQL Server에서 인증서를 사용하도록 구성됩니다. - SQL Server의 명명된 인스턴스: PowerShell을 사용하여 **%path%\\CreateMPReplicaCert.ps1 xxxxxx** 명령을 실행합니다. 여기서 **xxxxxx**는 SQL Server 인스턴스의 이름입니다. - 스크립트를 완료한 후 SQL Server 에이전트가 실행되고 있는지 확인합니다. 실행되고 있지 않으면 SQL Server 에이전트를 다시 시작합니다.
데이터베이스 복제 서버의 자체 서명된 인증서를 사용하도록 원격 관리 지점을 구성하려면
-
서버의 자체 서명된 인증서를 내보내려면 데이터베이스 복제 서버에서 다음 단계를 수행하세요.
시작, 실행을 차례로 클릭한 다음 mmc.exe를 입력합니다. 비어 있는 콘솔에서 파일을 클릭한 후 스냅인 추가/제거를 클릭합니다.
스냅인 추가/제거 대화 상자의 사용 가능한 스냅인 목록에서 인증서를 선택하고 추가를 클릭합니다.
인증서 스냅인 대화 상자에서 컴퓨터 계정을 선택한 후에 다음을 클릭합니다.
컴퓨터 선택 대화 상자에서 **로컬 컴퓨터: (이 콘솔이 실행되고 있는 컴퓨터)**가 선택되어 있는지 확인한 다음 마침을 클릭합니다.
스냅인 추가/제거 대화 상자에서 확인을 클릭합니다.
콘솔에서 **인증서(로컬 컴퓨터)**를 확장하고 개인을 확장한 후 인증서를 선택합니다.
이름이 ConfigMgr SQL Server 식별 인증서인 인증서를 마우스 오른쪽 단추로 클릭하고 모든 작업을 클릭한 후 내보내기를 선택합니다.
기본 옵션을 사용하여 인증서 내보내기 마법사를 완료하고 .cer 파일 이름 확장명으로 인증서를 저장합니다.
-
데이터베이스 복제 서버의 자체 서명된 인증서를 관리 지점의 신뢰할 수 있는 사용자 인증서 저장소에 추가하려면 관리 지점 컴퓨터에서 다음 단계를 수행하세요.
앞의 1.a단계부터 1.e단계까지 반복하여 관리 지점 컴퓨터에서 인증서 스냅인 MMC를 구성합니다.
콘솔에서 **인증서(로컬 컴퓨터)**와 신뢰할 수 있는 사용자를 차례로 확장하고 인증서를 마우스 오른쪽 단추로 클릭한 다음 모든 작업을 선택하고 가져오기를 선택하여 인증서 가져오기 마법사를 시작합니다.
가져올 파일 페이지에서 1.h단계에서 저장한 인증서를 선택한 후 다음을 클릭합니다.
인증서 저장소 페이지에서 모든 인증서를 다음 저장소에 저장을 선택하고 인증서 저장소를 신뢰할 수 있는 사용자로 설정한 후 다음을 클릭합니다.
마침을 클릭하여 마법사를 닫고 관리 지점의 인증서 구성을 완료합니다.
데이터베이스 복제본 서버에 대해 SQL Server Service Broker 구성
System Center 2012 Configuration Manager SP1 이상:
관리 지점의 데이터베이스 복제본으로 클라이언트 알림을 지원하려면 SQL Server Service Broker를 위해 사이트 데이터베이스 서버와 데이터베이스 복제 서버 간의 통신을 구성해야 합니다. 그러기 위해서는 다른 데이터베이스에 대한 정보를 사용하여 각 데이터베이스를 구성하고 보안 통신을 위해 두 데이터베이스 간에 인증서를 교환해야 합니다.
참고
다음 절차를 수행하기 전에 데이터베이스 복제 서버에서 사이트 데이터베이스 서버와의 초기 동기화를 성공적으로 완료해야 합니다.
다음 절차를 수행해도 SQL Server에서 사이트 데이터베이스 서버나 데이터베이스 복제 서버용으로 구성한 Service Broker 포트는 수정되지 않습니다. 대신 이 절차는 각 데이터베이스가 올바른 Service Broker 포트를 사용하여 다른 데이터베이스와 통신하도록 구성합니다.
사이트 데이터베이스 서버와 데이터베이스 복제 서버용으로 Service Broker를 구성하려면 다음 절차를 수행하세요.
데이터베이스 복제용으로 Service Broker를 구성하려면
-
SQL Server Management Studio를 사용하여 데이터베이스 복제 서버 데이터베이스에 연결한 후 다음 쿼리를 실행하여 데이터베이스 복제 서버에서 Service Broker를 사용하도록 설정합니다. ALTER DATABASE <복제 데이터베이스 이름> SET ENABLE_BROKER, HONOR_BROKER_PRIORITY ON WITH ROLLBACK IMMEDIATE
-
그 다음에는, 데이터베이스 복제 서버의 Service Broker에서 클라이언트 알림을 구성하고 Service Broker 인증서를 내보냅니다. 이렇게 하려면 한 번의 작업으로 Service Broker를 구성하고 인증서를 내보내는 SQL Server 저장 프로시저를 실행합니다. 저장 프로시저를 실행할 때 데이터베이스 복제 서버의 FQDN과 데이터베이스 복제 데이터베이스의 이름을 지정하고 인증서 파일을 내보낼 위치를 지정해야 합니다.
데이터베이스 복제 서버에서 필요한 세부 설정을 구성하려면 다음 쿼리를 실행하고 데이터베이스 복제 서버의 인증서를 내보냅니다. EXEC sp_BgbConfigSSBForReplicaDB '<복제 SQL Server FQDN>', '<복제 데이터베이스 이름>', '<인증서 백업 파일 경로>'
참고
데이터베이스 복제 서버가 SQL Server의 기본 인스턴스에 있지 않으면 이 단계에서 복제 데이터베이스 이름 외에 인스턴스 이름도 지정해야 합니다. 이렇게 하려면 <복제 데이터베이스 이름>을 인스턴스 이름\복제 데이터베이스 이름>으로 바꿉니다.
데이터베이스 복제 서버에서 인증서를 내보낸 후 인증서 사본을 기본 사이트 데이터베이스 서버에 저장합니다.
-
SQL Server Management Studio를 사용하여 기본 사이트 데이터베이스에 연결합니다. 기본 사이트 데이터베이스에 연결한 후 인증서를 가져오는 쿼리를 실행하고 데이터베이스 복제 서버에서 사용 중인 Service Broker 포트, 데이터베이스 복제 서버의 FQDN 및 데이터베이스 복제 데이터베이스의 이름을 지정합니다. 그러면 기본 사이트 데이터베이스가 Service Broker를 사용하여 데이터베이스 복제 서버의 데이터베이스와 통신하도록 구성됩니다.
다음 쿼리를 실행하여 데이터베이스 복제 서버에서 인증서를 가져오고 필요한 세부 설정을 지정합니다. EXEC sp_BgbConfigSSBForRemoteService 'REPLICA', '<SQL Service Broker 포트>', '<인증서 파일 경로>', '<복제 SQL Server FQDN>', '<복제 데이터베이스 이름>'
참고
데이터베이스 복제 서버가 SQL Server의 기본 인스턴스에 있지 않으면 이 단계에서 복제 데이터베이스 이름 외에 인스턴스 이름도 지정해야 합니다. 이렇게 하려면 <복제 데이터베이스 이름>을 인스턴스 이름\복제 데이터베이스 이름>으로 바꿉니다.
-
그 다음에는, 사이트 데이터베이스 서버에서 다음 명령을 실행하여 사이트 데이터베이스 서버의 인증서를 내보냅니다. EXEC sp_BgbCreateAndBackupSQLCert '<인증서 백업 파일 경로>'
사이트 데이터베이스 서버에서 인증서를 내보낸 후 인증서 사본을 데이터베이스 복제 서버에 저장합니다.
-
SQL Server Management Studio를 사용하여 데이터베이스 복제 서버 데이터베이스에 연결합니다. 데이터베이스 복제 서버 데이터베이스에 연결한 후 인증서를 가져오는 쿼리를 실행하고 기본 사이트의 사이트 코드 및 사이트 데이터베이스 서버에서 사용 중인 Service Broker 포트를 지정합니다. 그러면 데이터베이스 복제 서버가 Service Broker를 사용하여 기본 사이트의 데이터베이스와 통신하도록 구성됩니다.
다음 쿼리를 실행하여 사이트 데이터베이스 서버에서 인증서를 가져옵니다. EXEC sp_BgbConfigSSBForRemoteService '<사이트 코드>', '<SQL Service Broker 포트>', '<인증서 파일 경로>'
사이트 데이터베이스와 데이터베이스 복제 데이터베이스의 구성을 완료한 후 몇 분이 지나면 기본 사이트의 알림 관리자가 기본 사이트 데이터베이스에서 데이터베이스 복제본으로의 클라이언트 알림을 위해 Service Broker 대화를 설정합니다.
데이터베이스 복제본 사용을 위한 작업
사이트에서 데이터베이스 복제본을 사용할 때 다음 섹션의 정보를 사용하면 데이터베이스 복제본을 제거하거나, 데이터베이스 복제본을 사용하는 사이트를 제거하거나, 사이트 데이터베이스를 SQL Server의 새 설치로 이동하는 프로세스를 보완할 수 있습니다. 다음 섹션의 정보를 사용하여 게시를 삭제하는 경우 데이터베이스 복제본에 사용하는 SQL Server 버전의 트랜잭션 복제를 삭제하는 지침을 사용하세요. 예를 들어 SQL Server 2008 R2를 사용하는 경우 방법: 게시 삭제(복제 Transact-SQL 프로그래밍)를 참조하세요.
참고
데이터베이스 복제본용으로 구성된 사이트 데이터베이스를 복원한 후에, 데이터베이스 복제본을 사용하려면 먼저 게시 및 구독을 모두 다시 만드는 것을 포함해 각 데이터베이스 복제본을 다시 구성해야 합니다.
데이터베이스 복제본 제거
관리 지점에 대한 데이터베이스 복제본을 사용하는 경우 일정 기간 동안 데이터베이스 복제본을 제거한 다음 다시 구성해야 사용할 수 있습니다. 예를 들어 Configuration Manager 사이트를 새 서비스 팩으로 업그레이드하기 전에 데이터베이스 복제본을 제거해야 합니다. 사이트 업그레이드를 완료한 후에 데이터베이스 복제본을 사용할 수 있도록 복원할 수 있습니다.
데이터베이스 복제본을 제거하려면 다음 단계를 수행하세요.
Configuration Manager콘솔의 관리 작업 영역에서 사이트 구성을 확장한 다음 서버 및 사이트 시스템 역할을 선택하고 세부 정보 창에서 제거하려는 데이터베이스 복제본을 사용하는 관리 지점을 호스트하는 사이트 시스템 서버를 선택합니다.
사이트 시스템 역할 창에서 관리 지점을 마우스 오른쪽 단추로 클릭한 다음 속성을 선택합니다.
관리 지점 데이터베이스 탭에서 사이트 데이터베이스 사용을 선택하여 데이터베이스 복제본 대신 사이트 데이터베이스를 사용하도록 관리 지점을 구성합니다. 그런 다음 확인을 클릭하여 구성을 저장합니다.
그 다음에는 SQL Server Management Studio를 사용하여 다음 작업을 수행합니다.
사이트 서버 데이터베이스에서 데이터베이스 복제본에 대한 게시를 삭제합니다.
데이터베이스 복제 서버에서 데이터베이스 복제본에 대한 구독을 삭제합니다.
데이터베이스 복제 서버에서 복제 데이터베이스를 삭제합니다.
사이트 데이터베이스 서버에서 게시 및 배포를 사용하지 않도록 설정합니다. 게시 및 배포를 사용하지 않도록 설정하려면 복제 폴더를 마우스 오른쪽 단추로 클릭하고 게시 및 배포 해제를 클릭합니다.
게시, 구독, 복제 데이터베이스를 삭제하고 사이트 서버 데이터베이스에서 게시를 사용하지 않도록 설정하면 데이터베이스 복제본이 제거됩니다.
사이트 서버 제거
데이터베이스 복제본을 게시하는 사이트를 제거하기 전에 다음 단계를 수행하여 게시 및 구독을 정리하세요.
SQL Server Management Studio를 사용하여 사이트 서버 데이터베이스에서 데이터베이스 복제본 게시를 삭제합니다.
SQL Server Management Studio를 사용하여 이 사이트의 데이터베이스 복제본을 호스팅하는 각 원격 SQL Server에서 데이터베이스 복제본 구독을 삭제합니다.
사이트를 제거합니다.
사이트 서버 데이터베이스 이동
새 컴퓨터로 사이트 데이터베이스를 이동하는 경우 다음 단계를 수행하세요.
SQL Server Management Studio를 사용하여 사이트 서버 데이터베이스에서 데이터베이스 복제본에 대한 게시를 삭제합니다.
SQL Server Management Studio를 사용하여 이 사이트의 각 데이터베이스 복제 서버에서 데이터베이스 복제본에 대한 구독을 삭제합니다.
데이터베이스를 새 SQL Server 컴퓨터로 이동합니다. 자세한 내용은 사이트 및 계층 구성 관리 항목에서 사이트 데이터베이스 구성 수정 섹션을 참조하세요.
사이트 데이터베이스 서버에서 데이터베이스 복제본에 대한 게시를 다시 만듭니다. 자세한 내용은 데이터베이스 복제본을 게시하도록 사이트 데이터베이스 서버 구성 항목을 참조하세요.
각 데이터베이스 복제 서버에서 데이터베이스 복제본에 대한 구독을 다시 만듭니다. 자세한 내용은 데이터베이스 복제본 서버 구성 항목을 참조하세요.