Nota
O acesso a esta página requer autorização. Podes tentar iniciar sessão ou mudar de diretório.
O acesso a esta página requer autorização. Podes tentar mudar de diretório.
Este tópico descreve como desabilitar a publicação e a distribuição no SQL Server 2014 usando o SQL Server Management Studio, o Transact-SQL ou o RMO (Replication Management Objects).
É possível fazer o seguinte:
Exclua todos os bancos de dados de distribuição no Distribuidor.
Desabilite todos os Publicadores que usam o Distribuidor e exclua todas as publicações nesses Publicadores.
Exclua todas as assinaturas para as publicações. Os dados nos bancos de dados de publicação e assinatura não serão excluídos; no entanto, ele perde sua relação de sincronização com qualquer banco de dados de publicação. Se quiser que os dados no Assinante sejam excluídos, exclua-os manualmente.
Nesse Tópico
Antes de começar:
Para desabilitar a publicação e a distribuição usando:
Antes de começar
Pré-requisitos
- Para desabilitar a publicação e a distribuição, todos os bancos de dados de distribuição e publicação devem estar online. Se houver instantâneos de banco de dados de distribuição ou publicação, eles devem ser descartados antes de desabilitar a publicação e a distribuição. Um extrato de banco de dados é uma cópia offline de leitura única de um banco de dados e não está relacionado a um instantâneo de replicação. Para obter mais informações, confira Instantâneos de banco de dados (SQL Server).
Como usar o SQL Server Management Studio.
Desabilite a publicação e a distribuição usando o Assistente para Desabilitar Publicação e Distribuição.
Para desabilitar a publicação e a distribuição
Conecte-se ao Publicador ou Distribuidor que você deseja desabilitar no Microsoft SQL Server Management Studio e expanda a ramificação do servidor.
Clique com o botão direito do mouse na pasta Replicação e clique em Desabilitar Publicação e Distribuição.
Conclua as etapas no Assistente de Desabilitação de Publicação e Distribuição.
Usando Transact-SQL
A publicação e a distribuição podem ser desabilitadas programaticamente usando procedimentos armazenados de replicação.
Para desabilitar a publicação e a distribuição
Interrompa todos os trabalhos relacionados à replicação. Para obter uma lista de nomes de trabalho, consulte a seção "Segurança do agente no SQL Server Agent" do Modelo de Segurança do Replication Agent.
Em cada Assinante no banco de dados de assinatura, execute sp_removedbreplication para remover objetos de replicação do banco de dados. Esse procedimento armazenado não removerá trabalhos de replicação no Distribuidor.
No Publicador do banco de dados de publicação, execute sp_removedbreplication para remover objetos de replicação do banco de dados.
Se o Publicador usar um Distribuidor remoto, execute sp_dropdistributor.
No Distribuidor, execute sp_dropdistpublisher. Esse procedimento armazenado deve ser executado uma vez para cada Publicador registrado no Distribuidor.
No Distribuidor, execute sp_dropdistributiondb para excluir o banco de dados de distribuição. Esse procedimento armazenado deve ser executado uma vez para cada banco de dados de distribuição no Distribuidor. Isso também remove todos os trabalhos do Queue Reader Agent associados ao banco de dados de distribuição.
No Distribuidor, execute sp_dropdistributor para remover a designação do Distribuidor do servidor.
Observação
Se todos os objetos de publicação e distribuição de replicação não forem descartados antes de você executar sp_dropdistpublisher e sp_dropdistributor, esses procedimentos retornarão um erro. Para remover todos os objetos relacionados à replicação quando um Publicador ou Distribuidor é descartado, o parâmetro @no_checks deve ser definido como 1. Se um Publicador ou Distribuidor estiver offline ou inacessível, o parâmetro @ignore_distributor poderá ser definido como 1 para que eles possam ser descartados; no entanto, qualquer publicação e distribuição de objetos deixados para trás deve ser removida manualmente.
Exemplos (Transact-SQL)
Este script de exemplo remove objetos de replicação do banco de dados de assinatura.
-- Remove replication objects from the subscription database on MYSUB.
DECLARE @subscriptionDB AS sysname
SET @subscriptionDB = N'AdventureWorks2012Replica'
-- Remove replication objects from a subscription database (if necessary).
USE master
EXEC sp_removedbreplication @subscriptionDB
GO
Este script de exemplo desabilita a publicação e a distribuição em um servidor que é um Publicador e Distribuidor e descarta o banco de dados de distribuição.
-- This script uses sqlcmd scripting variables. They are in the form
-- $(MyVariable). For information about how to use scripting variables
-- on the command line and in SQL Server Management Studio, see the
-- "Executing Replication Scripts" section in the topic
-- "Programming Replication Using System Stored Procedures".
-- Disable publishing and distribution.
DECLARE @distributionDB AS sysname;
DECLARE @publisher AS sysname;
DECLARE @publicationDB as sysname;
SET @distributionDB = N'distribution';
SET @publisher = $(DistPubServer);
SET @publicationDB = N'AdventureWorks2012';
-- Disable the publication database.
USE [AdventureWorks2012]
EXEC sp_removedbreplication @publicationDB;
-- Remove the registration of the local Publisher at the Distributor.
USE master
EXEC sp_dropdistpublisher @publisher;
-- Delete the distribution database.
EXEC sp_dropdistributiondb @distributionDB;
-- Remove the local server as a Distributor.
EXEC sp_dropdistributor;
GO
Usando Objetos de Gerenciamento de Replicação (RMO)
Para desabilitar a publicação e a distribuição
Remova todas as assinaturas para publicações que usam o Distribuidor. Para obter mais informações, consulte Excluir uma assinatura pull e excluir uma assinatura push.
Remova todas as publicações que usam o Distribuidor e desabilite a publicação para todos os bancos de dados se o Publicador e o Distribuidor estiverem no mesmo servidor. Para obter mais informações, consulte Eliminar uma Publicação.
Crie uma conexão com o Distribuidor usando a classe ServerConnection .
Criar uma instância da classe DistributionPublisher. Especifique a Name propriedade e passe o ServerConnection objeto da etapa 3.
(Opcional) Chame o LoadProperties método para obter as propriedades do objeto e verificar se o Publicador existe. Se esse método retornar
false, o nome do Publicador definido na etapa 4 estava incorreto ou o Publicador não é usado por esse Distribuidor.Chame o método Remove . Passe um valor de
truepara força caso o Publicador e o Distribuidor estejam em servidores diferentes e quando o Publicador deve ser desinstalado no ambiente do Distribuidor sem primeiro verificar se as publicações ainda existem no Publicador.Criar uma instância da classe ReplicationServer. Passe o ServerConnection objeto da etapa 3.
Chame o método UninstallDistributor . Passe um valor de
truepara force para remover todos os objetos de replicação no Distribuidor sem antes verificar se todos os bancos de dados de publicação locais foram desabilitados e se os bancos de dados de distribuição foram desinstalados.
Exemplos (RMO)
Este exemplo remove o registro do Publicador no Distribuidor, remove o banco de dados de distribuição e desinstala o Distribuidor.
// Set the Distributor and publication database names.
// Publisher and Distributor are on the same server instance.
string publisherName = publisherInstance;
string distributorName = publisherInstance;
string distributionDbName = "distribution";
string publicationDbName = "AdventureWorks2012";
// Create connections to the Publisher and Distributor
// using Windows Authentication.
ServerConnection publisherConn = new ServerConnection(publisherName);
ServerConnection distributorConn = new ServerConnection(distributorName);
// Create the objects we need.
ReplicationServer distributor =
new ReplicationServer(distributorConn);
DistributionPublisher publisher;
DistributionDatabase distributionDb =
new DistributionDatabase(distributionDbName, distributorConn);
ReplicationDatabase publicationDb;
publicationDb = new ReplicationDatabase(publicationDbName, publisherConn);
try
{
// Connect to the Publisher and Distributor.
publisherConn.Connect();
distributorConn.Connect();
// Disable all publishing on the AdventureWorks2012 database.
if (publicationDb.LoadProperties())
{
if (publicationDb.EnabledMergePublishing)
{
publicationDb.EnabledMergePublishing = false;
}
else if (publicationDb.EnabledTransPublishing)
{
publicationDb.EnabledTransPublishing = false;
}
}
else
{
throw new ApplicationException(
String.Format("The {0} database does not exist.", publicationDbName));
}
// We cannot uninstall the Publisher if there are still Subscribers.
if (distributor.RegisteredSubscribers.Count == 0)
{
// Uninstall the Publisher, if it exists.
publisher = new DistributionPublisher(publisherName, distributorConn);
if (publisher.LoadProperties())
{
publisher.Remove(false);
}
else
{
// Do something here if the Publisher does not exist.
throw new ApplicationException(String.Format(
"{0} is not a Publisher for {1}.", publisherName, distributorName));
}
// Drop the distribution database.
if (distributionDb.LoadProperties())
{
distributionDb.Remove();
}
else
{
// Do something here if the distribition DB does not exist.
throw new ApplicationException(String.Format(
"The distribution database '{0}' does not exist on {1}.",
distributionDbName, distributorName));
}
// Uninstall the Distributor, if it exists.
if (distributor.LoadProperties())
{
// Passing a value of false means that the Publisher
// and distribution databases must already be uninstalled,
// and that no local databases be enabled for publishing.
distributor.UninstallDistributor(false);
}
else
{
//Do something here if the distributor does not exist.
throw new ApplicationException(String.Format(
"The Distributor '{0}' does not exist.", distributorName));
}
}
else
{
throw new ApplicationException("You must first delete all subscriptions.");
}
}
catch (Exception ex)
{
// Implement appropriate error handling here.
throw new ApplicationException("The Publisher and Distributor could not be uninstalled", ex);
}
finally
{
publisherConn.Disconnect();
distributorConn.Disconnect();
}
' Set the Distributor and publication database names.
' Publisher and Distributor are on the same server instance.
Dim publisherName As String = publisherInstance
Dim distributorName As String = subscriberInstance
Dim distributionDbName As String = "distribution"
Dim publicationDbName As String = "AdventureWorks2012"
' Create connections to the Publisher and Distributor
' using Windows Authentication.
Dim publisherConn As ServerConnection = New ServerConnection(publisherName)
Dim distributorConn As ServerConnection = New ServerConnection(distributorName)
' Create the objects we need.
Dim distributor As ReplicationServer
distributor = New ReplicationServer(distributorConn)
Dim publisher As DistributionPublisher
Dim distributionDb As DistributionDatabase
distributionDb = New DistributionDatabase(distributionDbName, distributorConn)
Dim publicationDb As ReplicationDatabase
publicationDb = New ReplicationDatabase(publicationDbName, publisherConn)
Try
' Connect to the Publisher and Distributor.
publisherConn.Connect()
distributorConn.Connect()
' Disable all publishing on the AdventureWorks2012 database.
If publicationDb.LoadProperties() Then
If publicationDb.EnabledMergePublishing Then
publicationDb.EnabledMergePublishing = False
ElseIf publicationDb.EnabledTransPublishing Then
publicationDb.EnabledTransPublishing = False
End If
Else
Throw New ApplicationException( _
String.Format("The {0} database does not exist.", publicationDbName))
End If
' We cannot uninstall the Publisher if there are still Subscribers.
If distributor.RegisteredSubscribers.Count = 0 Then
' Uninstall the Publisher, if it exists.
publisher = New DistributionPublisher(publisherName, distributorConn)
If publisher.LoadProperties() Then
publisher.Remove(False)
Else
' Do something here if the Publisher does not exist.
Throw New ApplicationException(String.Format( _
"{0} is not a Publisher for {1}.", publisherName, distributorName))
End If
' Drop the distribution database.
If distributionDb.LoadProperties() Then
distributionDb.Remove()
Else
' Do something here if the distribition DB does not exist.
Throw New ApplicationException(String.Format( _
"The distribution database '{0}' does not exist on {1}.", _
distributionDbName, distributorName))
End If
' Uninstall the Distributor, if it exists.
If distributor.LoadProperties() Then
' Passing a value of false means that the Publisher
' and distribution databases must already be uninstalled,
' and that no local databases be enabled for publishing.
distributor.UninstallDistributor(False)
Else
'Do something here if the distributor does not exist.
Throw New ApplicationException(String.Format( _
"The Distributor '{0}' does not exist.", distributorName))
End If
Else
Throw New ApplicationException("You must first delete all subscriptions.")
End If
Catch ex As Exception
' Implement appropriate error handling here.
Throw New ApplicationException("The Publisher and Distributor could not be uninstalled", ex)
Finally
publisherConn.Disconnect()
distributorConn.Disconnect()
End Try
Este exemplo desinstala o Distribuidor sem primeiro desabilitar bancos de dados de publicação local ou remover o banco de dados de distribuição.
// Set the Distributor and publication database names.
// Publisher and Distributor are on the same server instance.
string distributorName = publisherInstance;
// Create connections to the Distributor
// using Windows Authentication.
ServerConnection conn = new ServerConnection(distributorName);
conn.DatabaseName = "master";
// Create the objects we need.
ReplicationServer distributor = new ReplicationServer(conn);
try
{
// Connect to the Publisher and Distributor.
conn.Connect();
// Uninstall the Distributor, if it exists.
// Use the force parameter to remove everthing.
if (distributor.IsDistributor && distributor.LoadProperties())
{
// Passing a value of true means that the Distributor
// is uninstalled even when publishing objects, subscriptions,
// and distribution databases exist on the server.
distributor.UninstallDistributor(true);
}
else
{
//Do something here if the distributor does not exist.
}
}
catch (Exception ex)
{
// Implement appropriate error handling here.
throw new ApplicationException("The Publisher and Distributor could not be uninstalled", ex);
}
finally
{
conn.Disconnect();
}
' Set the Distributor and publication database names.
' Publisher and Distributor are on the same server instance.
Dim distributorName As String = publisherInstance
' Create connections to the Distributor
' using Windows Authentication.
Dim conn As ServerConnection = New ServerConnection(distributorName)
conn.DatabaseName = "master"
' Create the objects we need.
Dim distributor As ReplicationServer = New ReplicationServer(conn)
Try
' Connect to the Publisher and Distributor.
conn.Connect()
' Uninstall the Distributor, if it exists.
' Use the force parameter to remove everthing.
If distributor.IsDistributor And distributor.LoadProperties() Then
' Passing a value of true means that the Distributor
' is uninstalled even when publishing objects, subscriptions,
' and distribution databases exist on the server.
distributor.UninstallDistributor(True)
Else
'Do something here if the distributor does not exist.
End If
Catch ex As Exception
' Implement appropriate error handling here.
Throw New ApplicationException("The Publisher and Distributor could not be uninstalled", ex)
Finally
conn.Disconnect()
End Try
Consulte Também
Conceitos de Objetos de Gerenciamento de Replicação
Conceitos de procedimentos armazenados do sistema de replicação