Создание подписки для подписчика, отличного от подписчика SQL Server
В этом разделе описывается создание подписки для подписчика, не являющегося SQL Server, в SQL Server 2014 с помощью SQL Server Management Studio или Transact-SQL. Репликация транзакций и snapshot поддерживает публикацию данных для подписчиков, не являющихся SQL Server. Сведения о поддерживаемых платформах подписчиков см. в разделе Non-SQL Server Subscribers.
В этом разделе
Для создания подписки для подписчика, отличного от подписчика SQL Server, используется:
Использование среды SQL Server Management Studio
Чтобы создать подписку для подписчика, не являющегося SQL Server, выполните следующее:
Установите и настройте на распространителе SQL Server соответствующее клиентское программное обеспечение и соответствующий поставщик OLE DB. Дополнительные сведения см. в разделах Oracle Subscribers и IBM DB2 Subscribers.
Создайте публикацию с помощью мастера создания публикаций. Дополнительные сведения о создании публикаций см. в статьях Создание публикации и Создание публикации из базы данных Oracle. Укажите в мастере создания публикаций следующие параметры:
На странице Тип публикации выберите Публикация моментальных снимков или Публикация транзакций.
На странице Агент моментальных снимков снимите флажок Создать моментальный снимок немедленно.
Моментальный снимок создается после включения публикации для подписчиков, не относящихся кSQL Server , чтобы гарантировать, что агент моментальных снимков создаст скрипты моментального снимка и инициализации, пригодные для подписчиков, отличных отSQL Server .
Включите публикацию для подписчиков, не являющихся SQL Server, с помощью диалогового окна Свойства публикации — <Имя публикации>. Дополнительные сведения об этом шаге см. в разделе Publication Properties, Subscription Options .
Создайте подписку с помощью мастера создания подписок. В этом разделе содержатся дополнительные сведения об этом шаге.
(Необязательно) Измените свойство статьи pre_creation_cmd для сохранения таблиц на подписчике. В этом разделе содержатся дополнительные сведения об этом шаге.
Создайте моментальный снимок для публикации. В этом разделе содержатся дополнительные сведения об этом шаге.
Синхронизация подписки. Дополнительные сведения см. в статье Синхронизация принудительной подписки.
Включение публикации для подписчиков, отличных от подписчиков SQL Server
Подключитесь к издателю в среде SQL Server Management Studio, а затем раскройте узел сервера.
Раскройте папку Репликация , а затем папку Локальные публикации .
Щелкните правой кнопкой мыши публикацию, а затем щелкните Свойства.
На странице Параметры подписки выберите значение True для параметра Разрешать подписчики, отличные от подписчиков SQL Server. Выбор этого параметра изменяет количество свойств так, чтобы публикация была совместимой с подписчиками, отличными от подписчикаSQL Server .
Примечание
Если выбрано значение True , то свойство статьи pre_creation_cmd устанавливается в значение «drop». Этот параметр говорит о том, что репликация должна удалить таблицу на подписчике, если ее имя совпадает с именем таблицы в статье. Если на подписчике имеются таблицы, которые необходимо сохранить, вызовите хранимую процедуру sp_changearticle для каждой статьи, указав значение none в качестве параметра pre_creation_cmd:
sp_changearticle @publication= 'MyPublication', @article= 'MyArticle', @property='pre_creation_cmd', @value='none'
.Нажмите кнопку ОК. Будет предложено создать новый моментальный снимок для публикации. Если не нужно создавать его в данный момент, выполните позднее шаги, описанные в следующей процедуре «Инструкции».
Создание подписки для подписчика, отличного от подписчика SQL Server
Раскройте папку Репликация , а затем папку Локальные публикации .
Щелкните правой кнопкой мыши соответствующую публикацию, а затем щелкните Создать подписку.
Убедитесь в том, что на странице Расположение агента распространителя установлен флажок Выполнять все агенты на распространителе . Подписчики, отличные отSQL Server , не поддерживают выполнение агентов на подписчике.
На странице Подписчики щелкните Добавить подписчик , а затем — Добавить подписчик, отличный от подписчика SQL Server.
В диалоговом окне Добавление подписчика, отличного от подписчика SQL Server выберите тип подписчика.
Введите значение в поле Имя источника данных:
Для Oracle это будет введенное TNS-имя (transparent network substrate).
Для IBM это может быть любое имя. Обычно указывается сетевой адрес подписчика.
На этом этапе вводится имя источника данных, и учетные данные, указанные на шаге 9, этим мастером не проверяются. Они не используются репликацией, пока для этой подписки выполняется агент распространителя. Подключившись к подписчику с помощью клиентского средства (например, sqlplus для Oracle), убедитесь в том, что все значения проверены. Дополнительные сведения см. в разделах Oracle Subscribers и IBM DB2 Subscribers.
Нажмите кнопку ОК. Теперь на странице Подписчики мастера данный подписчик будет отображен в столбце Подписчик с доступным только для чтения значением (назначение по умолчанию) в столбце База данных подписки :
Для СУБД Oracle сервер имеет не более одной базы данных, поэтому нет необходимости указывать базу данных.
Для IBM DB2 база данных указывается в свойстве строки соединения DB2 Исходный каталог , которое может быть введено в поле Дополнительные параметры соединения , описанном далее в этом разделе.
На странице агент распространения Безопасность нажмите кнопку свойств (...) рядом с подписчиком, чтобы открыть диалоговое окно безопасность агент распространения.
В диалоговом окне Безопасность агента распространителя выполните следующие действия:
Введите в поля Учетная запись процесса, Парольи Подтверждение пароля учетную запись и пароль Microsoft Windows, под которыми будет выполняться агент распространителя, и установите локальное соединение с распространителем.
Эта учетная запись должна иметь следующие минимальные разрешения: членство в предопределенной роли базы данных db_owner в базе данных распространителя; членство в списке доступа к публикации (PAL); разрешения на чтение хранилища моментального снимка; разрешение на чтение каталога установки поставщика OLE DB. Дополнительные сведения о списке доступа к публикации см. в статье Организация безопасности издателя.
Под полем Соединиться с подписчикомвведите в поля Имя входа, Парольи Подтверждение пароля имя входа и пароль, которые следует использовать для соединения с подписчиком. Это имя входа уже должно быть сконфигурировано и иметь разрешения, достаточные для создания объектов в базе данных подписки.
В поле Дополнительные параметры соединения укажите любые параметры соединения для подписчика в форме строки соединения (Oracle не требует дополнительных параметров). Параметры разделяются точками с запятой. Ниже приводится пример строки соединения DB2 (переносы строк использованы для удобства чтения):
Provider=DB2OLEDB;Initial Catalog=MY_SUBSCRIBER_DB;Network Transport Library=TCP;Host CCSID=1252; PC Code Page=1252;Network Address=MY_SUBSCRIBER;Network Port=50000;Package Collection=MY_PKGCOL; Default Schema=MY_SCHEMA;Process Binary as Character=False;Units of Work=RUW;DBMS Platform=DB2/NT; Persist Security Info=False;Connection Pooling=True;
Большая часть параметров в строке зависят от настраиваемого сервера DB2, но параметр Обрабатывать двоичное значение как символ всегда должен иметь значение False. Параметр Исходный каталог должен иметь значение для идентификации базы данных подписки.
На странице Расписание синхронизации выберите из меню Расписание агента расписание для агента распространителя (обычно используется расписание Выполнять постоянно).
На странице Инициализация подписок укажите, следует ли инициализировать подписку и, если да, когда ее необходимо инициализировать:
Снимите флажок Инициализировать , только если были созданы все объекты и были добавлены все необходимые данные в базу данных подписки.
Чтобы после завершения выполнения этого мастера агент распространителя передал файлы моментальных снимков подписчику, выберите в раскрывающемся списке столбца Инициализировать, когда значение Немедленно . Выберите пункт При первой синхронизации , чтобы агент переслал файлы при следующем запланированном запуске.
На странице Действия мастера при желании можно написать скрипт для подписки. Дополнительные сведения см. в разделе Scripting Replication.
Сохранение таблиц на подписчике
- По умолчанию при разрешении публикации для подписчиков, не являющихся подписчикамиSQL Server , значение свойства статьи pre_creation_cmd устанавливается в «drop». Этот параметр говорит о том, что репликация должна удалить таблицу на подписчике, если ее имя совпадает с именем таблицы в статье. Если на подписчике уже существуют таблицы, которые необходимо сохранить, то для каждой статьи вызовите хранимую процедуру sp_changearticle , указав в качестве параметра pre_creation_cmdзначение «none».
sp_changearticle @publication= 'MyPublication', @article= 'MyArticle', @property='pre_creation_cmd', @value='none'
.
Создание моментального снимка для публикации
Раскройте папку Репликация , а затем папку Локальные публикации .
Щелкните правой кнопкой мыши публикацию, а затем щелкните Просмотреть состояние агента моментальных снимков.
В диалоговом окне Просмотр состояния агент моментальных снимков — <публикация> нажмите кнопку Пуск.
Когда агент моментальных снимков завершит создание моментального снимка, на экран будет выведено примерно следующее сообщение: «[100%] Создан моментальный снимок 17 статей».
Использование Transact-SQL
Принудительные подписки для подписчиков, не являющихся SQL Server, можно создавать программными средствами с помощью хранимых процедур репликации.
Важно!
По возможности предлагайте пользователям вводить учетные данные системы безопасности во время выполнения приложения. В случае необходимости хранения учетных данных в файле скрипта этот файл следует защищать во избежание несанкционированного доступа.
Создание принудительной подписки для публикации транзакций или публикации моментальных снимков на подписчики, отличные от SQL Server
Установите последнюю версию поставщика OLE DB для подписчика, отличного отSQL Server , на издателе и распространителе. Требования репликации к поставщику OLE DB см. в разделах Non-SQL Server Subscribers, Oracle Subscribers, IBM DB2 Subscribers.
На издателе в базе данных публикации убедитесь, что публикация поддерживает подписчиков, отличных от SQL Server, выполнив sp_helppublication (Transact-SQL).
Если значение
enabled_for_het_sub
равно 1, поддерживаются подписчики, отличные от SQL Server.Если значение
enabled_for_het_sub
равно 0, выполните sp_changepublication (Transact-SQL), указавenabled_for_het_sub
для @property иtrue
для @value.Примечание
Перед изменением значения
enabled_for_het_sub
наtrue
необходимо удалить все существующие подписки на публикацию. Нельзя присвоить параметруenabled_for_het_sub
значениеtrue
, если публикация также поддерживает обновляемые подписки. Изменение параметраenabled_for_het_sub
отразится на других свойствах публикации. Дополнительные сведения см. в статье Non-SQL Server Subscribers.
На издателе в базе данных публикации выполните sp_addsubscription (Transact-SQL). Задайте @publication, @subscriber, (назначение по умолчанию) в качестве значения параметра @destination_db, push в качестве значения параметра @subscription_type, а также 3 в качестве значения параметра @subscriber_type (задает поставщика OLE DB).
На издателе в базе данных публикации выполните sp_addpushsubscription_agent (Transact-SQL). Укажите следующее.
параметры @subscriberи @publication ;
значение (назначение по умолчанию) в параметре @subscriber_db;
Свойства не SQL Server источника данных для @subscriber_provider, @subscriber_datasrc, @subscriber_location, @subscriber_provider_string и @subscriber_catalog.
Учетные данные Microsoft Windows, с которыми агент распространения на распространитетеле выполняется для @job_login и @job_password.
Примечание
Подключения, выполняемые с использованием встроенной проверки подлинности Windows, всегда используют учетные данные Windows, указанные в @job_login и @job_password. Агент распространителя всегда создает локальные соединения с распространителем через встроенную систему проверки подлинности Windows. По умолчанию агент подключается к подписчику через встроенную систему проверки подлинности Windows;
значение 0 в параметре @subscriber_security_mode и сведения об имени входа поставщика OLE DB для параметров @subscriber_login и @subscriber_password;
Расписание задания агента распространителя для этой подписки. Дополнительные сведения см. в статье Specify Synchronization Schedules.
Важно!
При создании принудительной подписки на издателе с удаленным распространителем значения, указываемые для всех параметров, включая job_login и job_password, передаются распространителю в виде обычного текста. Прежде чем выполнять эту хранимую процедуру, необходимо зашифровать соединение между издателем и его удаленным распространителем. Дополнительные сведения см. в статье Включение шифрования соединений в компоненте Database Engine (диспетчер конфигурации SQL Server).
См. также:
IBM DB2 Subscribers
Oracle Subscribers
Другие подписчики, отличные от SQL Server
Replication System Stored Procedures Concepts
Рекомендации по защите репликации