Инициализация подписки вручную
В этом разделе описывается инициализация подписки вручную в SQL Server 2012 с помощью среды Среда SQL Server Management Studio или Transact-SQL. Обычно инициализация подписки производится через исходный моментальный снимок, однако подписку на публикацию можно инициализировать и другим способом. Для этого необходимо, чтобы на подписчике уже имелась схема и исходные данные.
В этом разделе
Перед началом работы выполните следующие действия.
Ограничения
Для инициализации подписки вручную используется:
Среда SQL Server Management Studio
Transact-SQL
Перед началом
Ограничения
- Если в базе данных, опубликованной с использованием репликации транзакций, между копированием данных и схемы на подписчик и ручной инициализацией подписки выполнялись какие-либо действия, то возникшие в результате этих действий изменения данных могут не реплицироваться на подписчик.
[Top]
Использование среды SQL Server Management Studio
Ручная инициализация подписки на публикацию производится путем копирования схемы (а также обычно данных) в базу данных подписки. Схема и данные должны соответствовать базе данных публикации. Затем на странице Инициализация подписок мастера создания подписок нужно указать, что для подписки не нужны схема и данные. Дополнительные сведения о доступе к этому мастеру см. в разделах Инициализация подписки на публикацию транзакций без моментального снимка и Создание подписки по запросу.
При первой синхронизации подписки объекты и метаданные, необходимые для репликации, копируются в базу данных подписки.
Инициализация подписки на публикацию вручную
Убедитесь, что схема и данные скопированы в базу данных подписки.
Снимите флажок Инициализировать на странице Инициализация подписок мастера создания подписок. Это действие необходимо выполнить для каждой подписки, требующей копирования только объектов и метаданных репликации.
[Top]
Использование Transact-SQL
Подписки можно инициализированы вручную с помощью хранимых процедур репликации.
Ручная инициализация подписки по запросу на публикацию транзакций
Убедитесь, что схема и данные существуют в базе данных подписки. Дополнительные сведения см. в разделе Инициализация подписки на публикацию транзакций без моментального снимка.
На издателе в базе данных публикации выполните хранимую процедуру sp_addsubscription. Задайте параметры @publication, @subscriber, укажите имя базы данных подписчика, содержащей публикуемые данные, в параметре @destination_db, значение pull в параметре @subscription_type, а также значение replication support only в параметре @sync_type. Дополнительные сведения см. в разделе Создание подписки по запросу.
Выполните процедуру sp_addpullsubscription на подписчике. Сведения об обновлении подписок см. в разделе Создание обновляемых подписок для публикаций транзакций.
Выполните процедуру sp_addpullsubscription_agent на подписчике. Дополнительные сведения см. в разделе Создание подписки по запросу.
Запустите агент распространителя, чтобы передать объекты репликации и загрузить последние изменения с издателя. Дополнительные сведения см. в разделе Синхронизация подписки по запросу.
Ручная инициализация принудительной подписки на публикацию транзакций
Убедитесь, что схема и данные существуют в базе данных подписки. Дополнительные сведения см. в разделе Инициализация подписки на публикацию транзакций без моментального снимка.
На издателе в базе данных публикации выполните хранимую процедуру sp_addsubscription. Укажите имя базы данных подписчика, содержащей публикуемые данные, в параметре @destination_db, значение push в параметре @subscription_type и значение replication support only в параметре @sync_type. Сведения об обновлении подписок см. в разделе Создание обновляемых подписок для публикаций транзакций.
На издателе в базе данных публикации выполните хранимую процедуру sp_addpushsubscription_agent. Дополнительные сведения см. в разделе Создание принудительной подписки.
Запустите агент распространителя, чтобы передать объекты репликации и загрузить последние изменения с издателя. Дополнительные сведения см. в разделе Синхронизация принудительной подписки.
Ручная инициализация подписки по запросу на публикацию слиянием
Убедитесь, что схема и данные существуют в базе данных подписки. Это можно сделать путем восстановления резервной копии базы данных публикации на подписчике.
Выполните процедуру sp_addmergesubscription на издателе. Укажите значения параметров @publication, @subscriber, @subscriber_db и значение pull в параметре @subscription_type. После этого подписка по запросу будет зарегистрирована.
На подписчике в базе данных, содержащей публикуемые данные, выполните хранимую процедуру sp_addmergepullsubscription. В параметре @sync_type укажите значение none.
Выполните процедуру sp_addmergepullsubscription_agent на подписчике. Дополнительные сведения см. в разделе Создание подписки по запросу.
Запустите агент слияния, чтобы передать объекты репликации и загрузить последние изменения с издателя. Дополнительные сведения см. в разделе Синхронизация подписки по запросу.
Ручная инициализация принудительной подписки на публикацию слиянием
Убедитесь, что схема и данные существуют в базе данных подписки. Это можно сделать путем восстановления резервной копии базы данных публикации на подписчике.
В базе данных публикации на издателе выполните процедуру sp_addmergepushsubscription_agent. Укажите имя базы данных на подписчике, содержащей публикуемые данные, в параметре @subscriber_db, значение push в параметре @subscription_type и значение none в параметре @sync_type.
На издателе в базе данных публикации выполните хранимую процедуру sp_addmergepushsubscription_agent. Дополнительные сведения см. в разделе Создание принудительной подписки.
Запустите агент слияния, чтобы передать объекты репликации и загрузить последние изменения с издателя. Дополнительные сведения см. в разделе Синхронизация принудительной подписки.
[Top]
См. также
Основные понятия
Инициализация подписки на публикацию транзакций без моментального снимка
Создание резервной копии и восстановление из копий реплицируемых баз данных