방법: 게시 및 배포 구성(RMO 프로그래밍)
RMO(복제 관리 개체)를 사용하여 프로그래밍 방식으로 복제 게시 및 배포를 구성할 수 있습니다.
단일 서버에서 게시 및 배포를 구성하려면
ServerConnection 클래스를 사용하여 서버 연결을 만듭니다.
ReplicationServer 클래스의 인스턴스를 만듭니다. 1단계에서 만든 ServerConnection을 전달합니다.
DistributionDatabase 클래스의 인스턴스를 만듭니다.
Name 속성을 데이터베이스 이름으로 설정하고 ConnectionContext 속성을 1단계에서 만든 ServerConnection으로 설정합니다.
InstallDistributor 메서드를 호출하여 배포자를 설치합니다. 3단계에서 만든 DistributionDatabase 개체를 전달합니다.
DistributionPublisher 클래스의 인스턴스를 만듭니다.
DistributionPublisher의 다음 속성을 설정합니다.
Name - 게시자의 이름
ConnectionContext - 1단계에서 만든 ServerConnection
DistributionDatabase - 5단계에서 만든 데이터베이스 이름
WorkingDirectory - 스냅숏 파일에 액세스하는 데 사용되는 공유
PublisherSecurity - 게시자에 연결할 때 사용되는 보안 모드. WindowsAuthentication을 사용하는 것이 좋습니다.
Create 메서드를 호출합니다.
원격 배포자를 사용하여 게시 및 배포를 구성하려면
ServerConnection 클래스를 사용하여 원격 배포자 서버에 대한 연결을 만듭니다.
ReplicationServer 클래스의 인스턴스를 만듭니다. 1단계에서 만든 ServerConnection을 전달합니다.
DistributionDatabase 클래스의 인스턴스를 만듭니다.
Name 속성을 데이터베이스 이름으로 설정하고 ConnectionContext 속성을 1단계에서 만든 ServerConnection으로 설정합니다.
InstallDistributor 메서드를 호출하여 배포자를 설치합니다. 원격 배포자에 연결할 때 게시자에서 사용되는 보안 암호 및 3단계에서 만든 DistributionDatabase 개체를 지정합니다. 자세한 내용은 배포자 보안 설정을 참조하십시오.
보안 정보 가능하면 런타임에 사용자에게 자격 증명을 입력하라는 메시지를 표시하십시오. 자격 증명을 저장해야 하는 경우 Microsoft Windows .NET Framework에서 제공하는 암호화 서비스를 사용합니다.
DistributionPublisher 클래스의 인스턴스를 만듭니다.
DistributionPublisher의 다음 속성을 설정합니다.
Name - 로컬 게시자 서버 이름
ConnectionContext - 1단계에서 만든 ServerConnection
DistributionDatabase - 5단계에서 만든 데이터베이스 이름
WorkingDirectory - 스냅숏 파일에 액세스하는 데 사용되는 공유
PublisherSecurity - 게시자에 연결할 때 사용되는 보안 모드. WindowsAuthentication을 사용하는 것이 좋습니다.
Create 메서드를 호출합니다.
ServerConnection 클래스를 사용하여 로컬 게시자 서버에 대한 연결을 만듭니다.
ReplicationServer 클래스의 인스턴스를 만듭니다. 9단계에서 만든 ServerConnection을 전달합니다.
InstallDistributor 메서드를 호출합니다. 5단계에서 지정된 원격 배포자 이름 및 원격 배포자 암호를 전달합니다.
보안 정보 가능하면 런타임에 사용자에게 자격 증명을 입력하라는 메시지를 표시하십시오. 자격 증명을 저장해야 하는 경우 Windows .NET Framework에서 제공하는 암호화 서비스를 사용합니다.
예
다음 예제에서는 로컬 배포자가 있는 게시자로 사용할 서버를 구성합니다.
// Set the server and database names
string distributionDbName = "distribution";
string publisherName = publisherInstance;
string publicationDbName = "AdventureWorks2008R2";
DistributionDatabase distributionDb;
ReplicationServer distributor;
DistributionPublisher publisher;
ReplicationDatabase publicationDb;
// Create a connection to the server using Windows Authentication.
ServerConnection conn = new ServerConnection(publisherName);
try
{
// Connect to the server acting as the Distributor
// and local Publisher.
conn.Connect();
// Define the distribution database at the Distributor,
// but do not create it now.
distributionDb = new DistributionDatabase(distributionDbName, conn);
distributionDb.MaxDistributionRetention = 96;
distributionDb.HistoryRetention = 120;
// Set the Distributor properties and install the Distributor.
// This also creates the specified distribution database.
distributor = new ReplicationServer(conn);
distributor.InstallDistributor((string)null, distributionDb);
// Set the Publisher properties and install the Publisher.
publisher = new DistributionPublisher(publisherName, conn);
publisher.DistributionDatabase = distributionDb.Name;
publisher.WorkingDirectory = @"\\" + publisherName + @"\repldata";
publisher.PublisherSecurity.WindowsAuthentication = true;
publisher.Create();
// Enable AdventureWorks as a publication database.
publicationDb = new ReplicationDatabase(publicationDbName, conn);
publicationDb.EnabledTransPublishing = true;
publicationDb.EnabledMergePublishing = true;
}
catch (Exception ex)
{
// Implement appropriate error handling here.
throw new ApplicationException("An error occured when installing distribution and publishing.", ex);
}
finally
{
conn.Disconnect();
}
' Set the server and database names
Dim distributionDbName As String = "distribution"
Dim publisherName As String = publisherInstance
Dim publicationDbName As String = "AdventureWorks2008R2"
Dim distributionDb As DistributionDatabase
Dim distributor As ReplicationServer
Dim publisher As DistributionPublisher
Dim publicationDb As ReplicationDatabase
' Create a connection to the server using Windows Authentication.
Dim conn As ServerConnection = New ServerConnection(publisherName)
Try
' Connect to the server acting as the Distributor
' and local Publisher.
conn.Connect()
' Define the distribution database at the Distributor,
' but do not create it now.
distributionDb = New DistributionDatabase(distributionDbName, conn)
distributionDb.MaxDistributionRetention = 96
distributionDb.HistoryRetention = 120
' Set the Distributor properties and install the Distributor.
' This also creates the specified distribution database.
distributor = New ReplicationServer(conn)
distributor.InstallDistributor((CType(Nothing, String)), distributionDb)
' Set the Publisher properties and install the Publisher.
publisher = New DistributionPublisher(publisherName, conn)
publisher.DistributionDatabase = distributionDb.Name
publisher.WorkingDirectory = "\\" + publisherName + "\repldata"
publisher.PublisherSecurity.WindowsAuthentication = True
publisher.Create()
' Enable AdventureWorks as a publication database.
publicationDb = New ReplicationDatabase(publicationDbName, conn)
publicationDb.EnabledTransPublishing = True
publicationDb.EnabledMergePublishing = True
Catch ex As Exception
' Implement appropriate error handling here.
Throw New ApplicationException("An error occured when installing distribution and publishing.", ex)
Finally
conn.Disconnect()
End Try