Поделиться через


Отключение публикации и распространения

В этом разделе описывается отключение публикации и распространения в SQL Server 2014 с помощью SQL Server Management Studio, Transact-SQL или объектов управления репликацией (RMO).

Доступны следующие действия:

  • Удалите все базы данных распространителя.

  • Отключите всех издателей, использующих распространитель, и удалите все публикации на этих издателях.

  • Удалите все подписки на публикации. Данные в базах данных публикации и подписки не будут удалены; однако она теряет связь синхронизации с любыми базами данных публикации. Если требуется удалить данные на подписчике, необходимо удалить их вручную.

В этом разделе

Перед началом работы

Предпосылки

  • Чтобы отключить публикацию и распространение, все базы данных рассылки и публикации должны быть в сети. Если для баз данных распространения или публикации существуют какие-либо моментальные снимки базы данных , их необходимо удалить перед отключением публикации и распространения. Моментальный снимок базы данных — это автономная копия базы данных только для чтения и не связана с моментальным снимком репликации. Дополнительные сведения см. в разделе "Моментальные снимки базы данных" (SQL Server).

Использование среды SQL Server Management Studio

Отключите публикацию и распространение с помощью мастера отключения публикации и распространения.

Отключение публикации и распространения

  1. Подключитесь к издателю или распространителю, который необходимо отключить в Microsoft SQL Server Management Studio, а затем разверните узел сервера.

  2. Щелкните правой кнопкой мыши папку репликации и выберите команду "Отключить публикацию и распространение".

  3. Выполните действия в мастере отключения публикации и распространения.

Использование Transact-SQL

Публикацию и распространение можно отключить программным способом с помощью хранимых процедур репликации.

Отключение публикации и распространения

  1. Остановите все задания, связанные с репликацией. Список имен заданий см. в разделе "Безопасность агента в агенте SQL Server" модели безопасности агента репликации.

  2. На каждом подписчике в базе данных подписки выполните sp_removedbreplication, чтобы удалить объекты репликации из базы данных. Эта хранимая процедура не удаляет задания репликации на распространитете.

  3. На узле издателя в базе данных публикации выполните sp_removedbreplication, чтобы удалить объекты репликации из базы данных.

  4. Если издатель использует удаленный распространитель, выполните sp_dropdistributor.

  5. На распределителе выполните sp_dropdistpublisher. Эта хранимая процедура должна выполняться один раз для каждого издателя, зарегистрированного на распространитете.

  6. На распространитее выполните sp_dropdistributiondb для удаления базы данных распространителя. Эта хранимая процедура должна выполняться один раз для каждой базы данных распространителя. Это также удаляет все задания агента чтения очередей, связанные с базой данных распространителя.

  7. На распространителе выполните sp_dropdistributor, чтобы удалить назначение распространителя с сервера.

    Замечание

    Если все объекты публикации и распространения репликации не удаляются перед выполнением sp_dropdistpublisher и sp_dropdistributor, эти процедуры возвращают ошибку. Чтобы удалить все объекты, связанные с репликацией при удалении издателя или распространителя, параметр @no_checks должен иметь значение 1. Если издатель или распространитель находится в автономном режиме или недоступен, параметр @ignore_distributor может иметь значение 1 , чтобы их можно было удалить; однако все объекты публикации и распространения, оставшиеся позади, должны быть удалены вручную.

Примеры (Transact-SQL)

В этом примере скрипт удаляет объекты репликации из базы данных подписки.

-- 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

В этом примере скрипт отключает публикацию и распространение на сервере, который является издателем и распространителем, и удаляет базу данных распространителя.

-- 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

Использование объектов управления репликацией (RMO)

Отключение публикации и распространения

  1. Отмените все подписки на публикации, использующие Дистрибьютор. Дополнительные сведения см. в разделе "Удаление подписки по запросу " и "Удаление push-подписки".

  2. Удалите все публикации, использующие распространитель, и отключите публикацию для всех баз данных, если издатель и распространитель находятся на одном сервере. Дополнительные сведения см. в разделе Удаление публикации.

  3. Создайте соединение с распространителем с помощью класса ServerConnection .

  4. Создайте экземпляр класса DistributionPublisher. Укажите свойство Name и передайте объект ServerConnection из шага 3.

  5. (Необязательно) LoadProperties Вызовите метод, чтобы получить свойства объекта и убедиться, что издатель существует. Если этот метод возвращается false, имя издателя, заданное на шаге 4, было неправильно или издатель не используется этим распространителем.

  6. Вызовите метод Remove . Передайте значение true для параметра force, если издатель и распространитель находятся на разных серверах и когда издатель должен быть удален на распространителе, не проверив предварительно, что публикации больше не существуют на издателе.

  7. Создайте экземпляр класса ReplicationServer. ServerConnection Передайте объект из шага 3.

  8. Вызовите метод UninstallDistributor . Передайте значение true для параметра force, чтобы удалить все объекты репликации на дистрибьюторе, не проверив заранее, что все локальные базы данных публикации отключены, а базы данных распространения удалены.

Примеры (RMO)

В этом примере удаляется регистрация издателя на распространителе, удаляется база данных распространителя и удаляется распространитель.

// 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

В этом примере Дистрибьютор удаляется без предварительного отключения локальной публикации баз данных или удаления дистрибуционной базы данных.

// 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

См. также

Концепции объектов управления репликацией
Основные понятия хранимых процедур системы репликации