Partilhar via


Criar uma publicação de um banco de dados Oracle

Este tópico descreve como criar uma publicação de um banco de dados Oracle no SQL Server 2014 usando SQL Server Management Studio ou Transact-SQL.

Neste tópico

Antes de começar

Pré-requisitos

  • Antes de criar uma publicação, você deve instalar o software Oracle no Distribuidor do Microsoft SQL Server, além de configurar o Oracle Database. Para obter mais informações, consulte Configure an Oracle Publisher (Configurar um publicador do Oracle).

Como usar o SQL Server Management Studio.

Crie uma publicação de instantâneo ou transacional a partir de um banco de dados Oracle com o Assistente de Nova Publicação.

A primeira vez que você cria uma publicação de um banco de dados Oracle, você deve identificar o Editor Oracle no Distribuidor do SQL Server (não é necessário fazer isso em publicações subsequentes do mesmo banco de dados). A identificação do Publicador Oracle pode ser realizada no Assistente para Nova Publicação ou na caixa de diálogo Propriedades do Distribuidor – <Distribuidor> ; este tópico mostra a caixa de diálogo Propriedades do Distribuidor – <Distribuidor> .

Para identificar o Editor Oracle no Distribuidor do SQL Server

  1. No SQL Server Management Studio, conecte-se à instância do SQL Server que o Editor Oracle usará como Distribuidor e, então, expanda o nó do servidor.

  2. Clique com o botão direito do mouse na pasta Replicação e em seguida clique em Propriedades do Distribuidor.

  3. Na página Editores da caixa de diálogo Propriedades do Distribuidor – <Distribuidor> , clique em Adicionar e, em seguida, clique em Adicionar Publicador Oracle.

  4. Na caixa de diálogo Conectar ao Servidor , clique no botão Opções .

  5. Na guia Logon :

    1. Insira o nome da instância do banco de dados Oracle ou selecione Procurar mais na caixa de combinação Instância do servidor .

    2. Selecione Autenticação Padrão da Oracle (recomendado) ou Autenticação do Windows.

      Se você selecionar Autenticação do Windows: o servidor Oracle deve estar configurado para permitir conexões usando credenciais do Windows (para obter mais informações, consulte a documentação do Oracle) e você deve estar atualmente conectado à mesma conta do Microsoft Windows especificada para o esquema de usuário administrativo de replicação.

    3. Se você selecionou Autenticação Padrão da Oracle, insira o logon e a senha do esquema de usuário administrativo de replicação que você criou no Editor Oracle durante a configuração.

  6. Na guia Propriedades de Conexão , selecione um tipo de Publicador de Gateway ou Completo.

    A opção Completa é projetada para fornecer publicações transacionais e de instantâneo com o conjunto completo de recursos com suporte para publicações Oracle. A opção Gateway fornece otimizações de projeto específicas para aprimorar o desempenho de casos em que a replicação serve como um gateway entre sistemas. A opção Gateway não poderá ser usada se você planejar publicar a mesma tabela em várias publicações transacionais. Uma tabela pode aparecer no máximo em uma publicação transacional e em qualquer número de publicações de instantâneo se você selecionar Gateway.

  7. Clique em Conectar, que cria uma conexão com o Editor Oracle e o configura para replicação. A caixa de diálogo Conectar ao Servidor é fechada e você é retornado à caixa de diálogo Propriedades do Distribuidor – <Distribuidor> .

    Observação

    Se houver qualquer problema com a configuração de rede, você receberá um aviso de erro nesse momento. Se experimentar problemas ao se conectar ao banco de dados Oracle, consulte a seção "O Distribuidor do SQL Server não pode se conectar à instância de banco de dados Oracle" em Troubleshooting Oracle Publishers.

  8. Clique em OK.

Para criar uma publicação de um banco de dados Oracle

  1. Conecte-se à instância do SQL Server que o Editor Oracle usará como Distribuidor e, então, expanda o nó do servidor.

  2. Expanda a pasta Replicação .

  3. Expanda a pasta Publicações Locais e em seguida clique em Nova Publicação Oracle.

  4. Na página Editor Oracle do Assistente de Nova Publicação, selecione o Editor Oracle. Se o Editor Oracle não estiver sendo exibido, clique em Adicionar Editor Oracle, que conduzirá você pelas etapas do procedimento anterior.

  5. Na página Tipo de Publicação , selecione Publicação de Instantâneo ou Publicação Transacional.

  6. Na página Artigos , selecione os objetos de banco de dados que você deseja publicar.

    Opcionalmente, descarte colunas de tabela expandindo uma tabela e desmarcando a caixa de seleção para uma ou mais colunas. Clique em Propriedades do Artigo para exibir e modificar propriedades de artigo e especificar mapeamentos de tipo de dados alternativos, se necessário. Para obter mais informações sobre mapeamentos de tipo de dados, consulte Especificar mapeamentos de tipo de dados para um Publicador Oracle.

  7. Na página Filtrar Linhas de Tabela , aplique filtros para publicar um subconjunto de dados de uma ou mais tabelas.

  8. Na página Snapshot Agent desmarque Criar um instantâneo imediatamente somente se você tiver criado todos os objetos e adicionado todos os dados necessários no banco de dados de assinatura.

  9. Na página Segurança do Agente especifique as credenciais para o Snapshot Agent (para todas as publicações) e Log Reader Agent (para publicações transacionais). Os agentes executam e fazem conexões com o Distribuidor SQL Server usando o contexto da conta do Windows Microsoft que você especificar. Os agentes fazem conexão com o banco de dados Oracle usando o contexto da conta que você especificou como esquema de usuário administrativo de replicação. Para obter mais informações, consulte Configure an Oracle Publisher (Configurar um publicador do Oracle).

    Para obter mais informações sobre as permissões necessárias para cada agente, consulte Replication Agent Security Model e Replication Security Best Practices.

  10. Na página Ações do Assistente , opcionalmente faça script da publicação. Para obter mais informações, consulte Scripting Replication.

  11. Na página Concluir o Assistente , especifique um nome para a publicação.

Usando o Transact-SQL

Após a configuração do Oracle Database como um Publicador, é possível criar uma publicação transacional ou instantânea da mesma maneira como você faria de um Publicador do Microsoft SQL Server, usando os procedimentos armazenados do sistema.

Para criar uma publicação Oracle

  1. Configure o banco de dados Oracle como um Publicador. Para obter mais informações, consulte Configure an Oracle Publisher (Configurar um publicador do Oracle).

  2. Se um Distribuidor remoto não existir, configure o Distribuidor remoto. Para obter mais informações, consulte Configure Publishing and Distribution.

  3. No Distribuidor remoto que o Publicador Oracle usará, execute sp_adddistpublisher (Transact-SQL). Especifique o nome TNS (Transparent Network Substrate) da instância do banco de dados Oracle para @publisher e um valor de ORACLE ou ORACLE GATEWAY para @publisher_type. Specify o modo de segurança usado ao conectar o Publicador Oracle ao Distribuidor do SQL Server remoto como um dos seguintes:

    • Para usar a Autenticação Padrão oracle, o padrão, especifique um valor 0 para @security_mode, o logon do esquema de usuário administrativo de replicação criado no Publicador Oracle durante a configuração para @login e a senha para @password.

      Importante

      Quando possível, solicite que os usuários insiram as credenciais de segurança em tempo de execução. Se armazenar credenciais em um arquivo de script, proteja o arquivo para evitar acesso não autorizado.

    • Para usar a Autenticação do Windows, especifique um valor de 1 para @security_mode.

      Observação

      Para usar a Autenticação Windows, o servidor Oracle deve estar configurado para permitir conexões usando as credenciais do Windows (para obter mais informações, consulte a documentação do Oracle) e você deve estar conectado à mesma conta Microsoft Windows especificada para o esquema de replicação do usuário administrativo.

  4. Crie um trabalho do Log Reader Agent para o banco de dados de publicação.

    • Se você não tiver certeza se existe um trabalho do Log Reader Agent para um banco de dados publicado, execute sp_helplogreader_agent (Transact-SQL) no Distribuidor usado pelo Publicador Oracle no banco de dados de distribuição. Especifique o nome do Publicador Oracle para @publisher. Se o conjunto de resultados estiver vazio, será preciso criar um trabalho do Log Reader Agent.

    • Se já houver um trabalho do Log Reader Agent no banco de dados de publicação, passe para a etapa 5.

    • No Distribuidor usado pelo Publicador Oracle no banco de dados de distribuição, execute sp_addlogreader_agent (Transact-SQL). Especifique as credenciais do Windows sob as quais o agente é executado para @job_login e @job_password.

      Observação

      O parâmetro @job_login deve corresponder ao logon fornecido na etapa 3. Não forneça informações de segurança do publicador. O Log Reader Agent se conecta ao Publicador usando as informações de segurança fornecidas na etapa 3.

  5. No Distribuidor no banco de dados de distribuição, execute sp_addpublication (Transact-SQL) para criar a publicação. Para obter mais informações, consulte Criar uma assinatura.

  6. No Distribuidor no banco de dados de distribuição, execute sp_addpublication_snapshot (Transact-SQL). Especifique o nome da publicação usado na etapa 4 para @publication e as credenciais do Windows sob as quais o Agente de Instantâneo é executado para @job_name e @password. Para usar a Autenticação Padrão oracle ao se conectar ao Publicador, você também deve especificar um valor 0 para @publisher_security_mode e as informações de logon do Oracle para @publisher_login e @publisher_password. Isso cria um trabalho do Agente de Instantâneo para a publicação.

Consulte Também

Configurar um Publicador Oracle
Publicar dados e objetos de banco de dados
Configurar o trabalho do conjunto de transações para um Publicador Oracle (programação Transact-SQL de replicação)
Visão geral da publicação do Oracle
Script para conceder permissões da Oracle