管理ポイントのデータベース レプリカの構成
適用対象: 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 を実行する 1 つまたは複数のコンピューターを構成すると、そのサイトの複数の管理ポイントが同じデータベースのレプリカを使用できます。 管理ポイントでデータベースのレプリカを使用すると、その管理ポイントはデータベースのレプリカをホストする SQL Server コンピューターにデータを要求します。 サイト データベース サーバーに直接要求する代わりに、要求がデータベース レプリカ サーバーに送られます。このため、クライアント ポリシーに頻繁に要求を行うクライアントが多数ある場合に、この構成を使用すると、サイト データベース サーバーに対する CPU 処理の要件が低減されます。
データベースのレプリカを使用する場合は、サイト データベース サーバーおよび各データベース レプリカ サーバーを定期的に監視し、それらの間でレプリケーションが実行されていること、およびデータベース レプリカ サーバーのパフォーマンスがサイトおよびクライアントで必要とされるパフォーマンスに対して十分であることを確認します。
データベースのレプリカを構成および管理するときに、次のセクションを参照してください。
データベースのレプリカを使用するための構成
データベースのレプリカを使用するための操作
データベースのレプリカのアンインストール
サイト サーバーのアンインストール
サイト サーバー データベースの移動
データベースのレプリカを使用するための構成
データベースのレプリカを使用するには、次のすべての構成が必要です。
サイト データベース サーバーおよびデータベース レプリカ サーバーの SQL Server に、[SQL Server レプリケーション] がインストールされている必要があります。
サイト データベースがデータベースのレプリカを発行する必要があります。
データベースのレプリカをホストするリモートの各 SQL Server コンピューターが、発行されたデータベースのレプリカをサブスクライブする必要があります。
データベースのレプリカを使用してデータベース レプリカ サーバーおよびデータベースのレプリカと通信する各管理ポイントを構成する必要があります。
データベースのレプリカをホストする各 SQL Server コンピューターには、リモート コンピューターでデータベース レプリカ サーバーと通信するために使用する、管理ポイントの自己署名入り証明書がある必要があります。
2 GB の [テキスト レプリケーションの最大サイズ] をサポートするように、サイト データベースとデータベースの各レプリカに使用する SQL Server を構成する必要があります。 SQL Server 2012 でこれを構成する方法の例については、「max text repl size サーバー構成オプションの構成」を参照してください。
データベースのレプリカを構成するためには、以下のセクションの手順を完了する必要があります。
データベースのレプリカを発行するようにサイト データベース サーバーを構成する
データベース レプリカ サーバーの構成
データベースのレプリカを使用するための管理ポイントの構成
データベース レプリカ サーバーの自己署名入り証明書の構成
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 を実行できます。 サポートされている 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 を選択し、[次へ] をクリックします。
[配布エージェントの場所] ページで、[サブスクライバーで各エージェントを実行する (プル サブスクリプション)] を選択し、[次へ] をクリックします。
[サブスクライバー] ページで、次のいずれかの操作を行います。
データベースのレプリカに使用するデータベース レプリカ サーバーから既存のデータベースを選択して、[OK] をクリックします。
[新しいデータベース] を選択して、データベースのレプリカの新しいデータベースを作成します。 [新しいデータベース] ページで、データベースの名前を指定し、[OK] をクリックします。
[次へ] をクリックして、続行します。
[配布エージェントのセキュリティ] ページで、ダイアログ ボックスの [サブスクライバー接続] 行の [プロパティ] ボタン (...) をクリックしてから、接続のセキュリティ設定を構成します。
ヒント プロパティ ボタン (...) は、ダイアログ ボックスの 4 列目にあります。
セキュリティ設定:
配布エージェント処理を実行するアカウント (プロセスのアカウント) を構成します。
SQL Server エージェントをローカル システムとして実行する場合は、[SQL Server エージェント サービスのアカウントで実行する (これは推奨されるセキュリティのベスト プラクティスではありません)] を選択します。
SQL Server エージェントを別のアカウントを使用して実行する場合は、[次の Windows アカウントで実行する] を選択して、そのアカウントを構成します。 Windows アカウントまたは SQL Server アカウントを指定できます。
重要 配布エージェントを実行するアカウントに、発行元へのアクセス許可をプル サブスクリプションとして付与する必要があります。 これらのアクセス許可の構成の詳細については、SQL Server TechNet Library の「ディストリビューション エージェント セキュリティ」を参照してください。
[ディストリビューターに接続] で、[プロセスのアカウントを借用する] を選択します。
[サブスクライバーに接続] で、[プロセスのアカウントを借用する] を選択します。
接続のセキュリティ設定を構成したら、[OK] をクリックして設定を保存してから、[次へ] をクリックします。
[同期スケジュール] ページの [エージェント スケジュール] リスト ボックスで、[スケジュールの定義] を選択し、[新しいジョブ スケジュール] を構成します。 ジョブを行う頻度を [毎日] に、繰り返す間隔を [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) マネージャー] を開きます。
管理ポイントが使用する Web サイトを選択して、[認証] を開きます。
[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」と入力します。 空のコンソールで、[ファイル] をクリックし、次に [スナップインの追加と削除] をクリックします。
[スナップインの追加と削除] ダイアログ ボックスで、[利用できるスナップイン] リストから [証明書] を選択し、[追加] をクリックします。
[証明書スナップイン] ダイアログボックスで [コンピューター アカウント] を選択し、[次へ] をクリックします。
[コンピューターの選択] ダイアログ ボックスで、[ローカル コンピューター: (このコンソールを実行しているコンピューター)] が選択されていることを確認して、[完了] をクリックします。
[スナップインの追加と削除] ダイアログ ボックスで、[OK] をクリックします。
[コンソール] ウィンドウで [証明書 (ローカル コンピューター)]、[個人] の順に展開して、[証明書] を選択します。
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 にサイト データベース サーバーとデータベース レプリカ サーバー間の通信を構成する必要があります。 そのためには、他のデータベースの情報を使って各データベースを構成し、通信をセキュリティで保護するために 2 つのデータベース間で証明書を交換する必要があります。
[!メモ]
以下の手順を実行する前に、データベース レプリカ サーバーでサイト データベース サーバーとの最初の同期が正常に完了する必要があります。
以下の手順を実行しても、サイト データベース サーバーまたはデータベース レプリカ サーバーの SQL Server に構成されているサービス ブローカー ポートは変更されません。 代わりに、この手順で、正しいサービス ブローカー ポートを使って他のデータベースと通信するように、各データベースが構成されます。
サイト データベース サーバーとデータベース レプリカ サーバーにサービス ブローカーを構成するには、次の手順を実行します。
データベースのレプリカにサービス ブローカーを構成するには
-
SQL Server Management Studio を使用して、データベース レプリカ サーバーのデータベースに接続してから、次のクエリを実行してデータベース レプリカ サーバーでサービス ブローカーを有効にします。ALTER DATABASE <レプリカ データベース名> SET ENABLE_BROKER, HONOR_BROKER_PRIORITY ON WITH ROLLBACK IMMEDIATE
-
次に、データベース レプリカ サーバーで、クライアント通知を行うようにサービス ブローカーを構成し、サービス ブローカーの証明書をエクスポートします。 これを行うには、サービス ブローカーを構成する SQL Server ストアド プロシージャを実行して、証明書を 1 回の操作でエクスポートします。 ストアド プロシージャを実行するときに、データベース レプリカ サーバーの FQDN、データベースのレプリカのデータベース名、および証明書ファイルをエクスポートする場所を指定する必要があります。
次のクエリを実行して、必要な情報をデータベース レプリカ サーバーに構成し、データベース レプリカ サーバーの証明書をエクスポートします。EXEC sp_BgbConfigSSBForReplicaDB '<レプリカ SQL Server の FQDN>', '<レプリカ データベース名>', '<証明書バックアップ ファイルのパス>'
[!メモ]
データベース レプリカ サーバーが SQL Server の既定のインスタンスに配置されていない場合は、この手順で、レプリカ データベース名に加えてインスタンス名も指定する必要があります。 それには、<レプリカ データベース名> を <インスタンス名\レプリカ データベース名> に置き換えます。
データベース レプリカ サーバーから証明書をエクスポートしたら、証明書のコピーをプライマリ サイトのデータベース サーバーに配置します。
-
SQL Server Management Studio を使用して、プライマリ サイトのデータベースに接続します。 プライマリ サイトのデータベースに接続したら、クエリを実行して証明書をインポートし、データベース レプリカ サーバーで使用するサービス ブローカー ポート、データベース レプリカ サーバーの FQDN、およびデータベースのレプリカのデータベース名を指定します。 これにより、サービス ブローカーを使用してデータベース レプリカ サーバーのデータベースと通信するように、プライマリ サイトのデータベースが構成されます。
次のクエリを実行してデータベース レプリカ サーバーから証明書をインポートし、必要な情報を指定します。EXEC sp_BgbConfigSSBForRemoteService 'REPLICA', '<SQL のサービス ブローカー ポート>', '<証明書のファイル パス>', '<レプリカの SQL Server の FQDN>', '<レプリカ データベース名>'
[!メモ]
データベース レプリカ サーバーが SQL Server の既定のインスタンスに配置されていない場合は、この手順で、レプリカ データベース名に加えてインスタンス名も指定する必要があります。 それには、<レプリカ データベース名> を <インスタンス名\レプリカ データベース名> に置き換えます。
-
次に、サイト データベース サーバーで、次のコマンドを実行してサイト データベース サーバーの証明書をエクスポートします。EXEC sp_BgbCreateAndBackupSQLCert '<証明書のバックアップ ファイル パス>'
サイト データベース サーバーから証明書をエクスポートしたら、証明書のコピーをデータベース レプリカ サーバーに配置します。
-
SQL Server Management Studio を使用して、データベース レプリカ サーバーのデータベースに接続します。 データベース レプリカ サーバーのデータベースに接続したら、クエリを実行して証明書をインポートし、プライマリ サイトのサイト コードと、サイト データベース サーバーで使用するサービス ブローカー ポートを指定します。 これにより、サービス ブローカーを使用してプライマリ サイトのデータベースと通信するように、データベース レプリカ サーバーが構成されます。
次のクエリを実行して、サイト データベース サーバーから証明書をインポートします。EXEC sp_BgbConfigSSBForRemoteService '<サイト コード>', '<SQL のサービス ブローカー ポート>', '<証明書のファイル パス>'
サイト データベースとデータベースのレプリカ データベースの構成を完了して数分すると、プライマリ サイトの通知マネージャーによって、プライマリ サイト データベースからデータベースのレプリカへのクライアント通知を行うための Service Broker メッセージ交換が設定されます。
データベースのレプリカを使用するための操作
サイトでデータベースのレプリカを使用する場合は、データベースのレプリカのアンインストール、データベースのレプリカを使用するサイトのアンインストール、または SQL Server の新しいインストールへのサイト データベースの移動を行うための補足する手順として、以下のセクションの情報を参照してください。 以下のセクションの情報を参照してパブリケーションを削除する場合は、データベースのレプリカに使用しているバージョンの SQL Server のトランザクション レプリケーションを削除する手順に従ってください。 たとえば、SQL Server 2008 R2 を使用する場合、「パブリケーションを削除する方法 (レプリケーション Transact-SQL プログラミング)」を参照してください。
[!メモ]
データベースのレプリカ用に構成されたサイト データベースを復元した後で、データベースのレプリカを使用するためには、データベースの各レプリカを再構成して、パブリケーションとサブスクリプションの両方を再作成する必要があります。
データベースのレプリカのアンインストール
管理ポイントにデータベースのレプリカを使用する場合、データベースのレプリカをしばらくの間アンインストールしてから、使用するには再構成することが必要になる可能性があります。 たとえば、Configuration Manager サイトを新しいサービス パックにアップグレードする前に、データベースのレプリカを削除する必要があります。 サイトのアップグレードが完了した後で、データベースのレプリカを復元して使用することができます。
データベースのレプリカをアンインストールするには、次の手順を実行します。
Configuration Manager コンソールの [管理] ワークスペースで、[サイトの構成] を展開して [サーバーとサイト システムの役割] を選択します。それから、詳細ウィンドウで、アンインストール対象のデータベース レプリカを使用している管理ポイントをホストしているサイト システム サーバーを選択します。
[サイト システムの役割] ウィンドウで、[管理ポイント] を右クリックして [プロパティ] を選択します。
[管理ポイントのデータベース] タブで [サイト データベースを使用する] を選択し、データベースのレプリカではなくサイト データベースを使用する管理ポイントを構成します。 次に、[OK] をクリックして構成を保存します。
SQL Server Management Studio を使用して、次のタスクを実行します。
サイト サーバー データベースからデータベースのレプリカのパブリケーションを削除する。
データベース レプリカ サーバーからデータベースのレプリカのサブスクリプションを削除する。
データベース レプリカ サーバーからレプリカ データベースを削除する。
サイト データベース サーバーでパブリッシングとディストリビューションを無効にする。 パブリッシングとディストリビューションを無効にするには、Replication フォルダーを右クリックしてから、[パブリッシングおよびディストリビューションを無効にする] をクリックします。
サイト データベース サーバーでパブリケーション、サブスクリプション、レプリカ データベースを削除し、パブリッシングを無効にすると、データベースのレプリカがアンインストールされます。
サイト サーバーのアンインストール
データベースのレプリカを発行するサイトをアンインストールする前に、次の手順に従って、パブリケーションおよびサブスクリプションをクリーンアップします。
SQL Server Management Studio を使用して、サイト サーバー データベースからデータベースのレプリカのパブリケーションを削除します。
SQL Server Management Studio を使用して、このサイトのデータベースのレプリカをホストする各リモート SQL Server から、データベースのレプリカのサブスクリプションを削除します。
サイトをアンインストールします。
サイト サーバー データベースの移動
サイト データベースを新しいコンピューターに移動する場合は、次の手順に従います。
SQL Server Management Studio を使用して、サイト サーバー データベースからデータベースのレプリカのパブリケーションを削除します。
SQL Server Management Studio を使用して、このサイトの各データベース レプリカ サーバーから、データベースのレプリカのサブスクリプションを削除します。
データベースを新しい SQL Server コンピューターに移動します。 詳細については、「サイト データベースの構成の変更」トピックの「サイトと階層の構成の管理」セクションを参照してください。
サイト データベース サーバーにデータベースのレプリカのパブリケーションを再作成します。 詳細については、「データベースのレプリカを発行するようにサイト データベース サーバーを構成する」をご覧ください。
各データベース レプリカ サーバーにデータベースのレプリカのサブスクリプションを再作成します。 詳細については、「データベース レプリカ サーバーの構成」をご覧ください。