Compartilhar via


Inicializar uma assinatura transacional de um backup

Aplica-se: SQL Server

Embora uma assinatura a uma publicação transacional seja geralmente inicializada com um instantâneo, é possível inicializar uma assinatura de backup usando procedimentos de replicação armazenados. Para obter mais informações, consulte Initialize a Transactional Subscription Without a Snapshot.

Para inicializar um assinante transacional a partir de backup

  1. Para uma publicação existente, certifique-se de que a publicação dê suporte à capacidade de inicializar do backup, executando sp_helppublication (Transact-SQL) no Publicador no banco de dados de publicação. Observe o valor de allow_initialize_from_backup no conjunto de resultados.

    • Se o valor for 1, a publicação oferece suporte a essa funcionalidade.

    • Se o valor for 0, execute sp_changepublication (Transact-SQL) no Publicador do banco de dados de publicação. Especifique um valor igual a allow_initialize_from_backup para @property e um valor igual a true para @value.

  2. Para uma nova publicação, execute sp_addpublication (Transact-SQL) no Publicador do banco de dados de publicação. Especifique um valor de true para allow_initialize_from_backup. Para obter mais informações, consulte Criar uma assinatura.

    Aviso

    Para evitar perder dados do assinante, ao usar sp_addpublication ou sp_changepublication com @allow_initialize_from_backup = N'true', sempre use @immediate_sync = N'true'.

  3. Crie um backup do banco de dados de publicação usando a instrução BACKUP (Transact-SQL).

  4. Restaure o backup no Assinante usando a instrução RESTORE (Transact-SQL).

  5. No Publicador no banco de dados de publicação, execute o procedimento armazenado sp_addsubscription (Transact-SQL). Especifique os seguintes parâmetros:

    • @sync_type – valor igual a inicializar com backup.

    • @backupdevicetype – o tipo de dispositivo de backup: lógico (padrão), disco ou fita.

    • @backupdevicename – o dispositivo de backup lógico ou físico a ser usado para a restauração.

      Para um dispositivo lógico, especifique o nome do dispositivo de backup especificado quando sp_addumpdevice foi usado para criar o dispositivo.

      Para um dispositivo físico, especifique um caminho completo e nome de arquivo, como DISK = 'C:\Program Files\Microsoft SQL Server\MSSQL13.MSSQLSERVER\BACKUP\Mybackup.dat' ou TAPE = '\\.\TAPE0'.

    • (Opcional) @password – uma senha fornecida durante a criação do conjunto de backup.

    • (Opcional) @mediapassword – uma senha fornecida durante a formatação do conjunto de mídias.

    • (Opcional) @fileidhint – identificador do conjunto de backup a ser restaurado. Por exemplo, especificar 1 indica o primeiro conjunto de backup na mídia de backup e 2 indica o segundo conjunto de backup.

    • (Opcional para dispositivos de fita) @unload – especifique um valor igual a 1 (padrão) se a fita deve ser descarregada da unidade após a conclusão da restauração e 0 se ela não deve ser descarregada.

  6. (Opcional) Para uma assinatura pull, execute sp_addpullsubscription (Transact-SQL) e sp_addpullsubscription_agent (Transact-SQL) no Assinante, no banco de dados de assinatura. Para obter mais informações, consulte Create a Pull Subscription.

  7. (Opcional) Iniciar o Distribution Agent. Para obter mais informações, consulte Synchronize a Pull Subscription ou Synchronize a Push Subscription.