Configurando um Editor Oracle

As publicações dos Editores Oracle são criadas da mesma forma que são criados os instantâneos e as publicações transacionais mas, antes de criar uma publicação de um Publicador Oracle, você deverá completar as etapas a seguir (etapas um, três e quatro que estão detalhadamente descritas neste tópico):

  1. Crie um usuário administrativo de replicação no banco de dados do Oracle, usando o script fornecido.

  2. Para as tabelas que você publicará, conceda permissão SELECT diretamente em cada uma delas (não através de uma função) ao usuário administrativo Oracle que você criou na etapa 1.

  3. Instale o software do cliente Oracle e o provedor OLE DV no Distribuidor MicrosoftSQL Server e, em seguida, pare e reinicie a instância SQL Server . Se o Distribuidor estiver executando em uma plataforma de 64-bit, você deverá usar a versão de 64 bits do provedor OLE DB do Oracle.

  4. Configure o banco de dados Oracle como um Publicador no Distribuidor SQL Server .

Para uma lista de objetos que podem ser replicados de banco de dados Oracle, consulte Considerações de design e limitações para Editores Oracle.

ObservaçãoObservação

Você deve ser um membro da função de servidor fixa sysadmin para habilitar um Publicador ou Distribuidor e para criar uma publicação Oracle ou uma assinatura de uma publicação Oracle.

Criando o esquema de usuários administrativo de replicação no banco de dados Oracle

Os agentes de replicação se conectam ao banco de dados Oracle, e executam operações no contexto de um esquema de usuário que você deve criar. Um número de permissões deve ser concedido ao esquema, os quais estão listados na próxima seção. Esse esquema contém todos os objetos criados pelo processo de replicação MicrosoftSQL Server no Publicador Oracle, com a exceção de um sinônimo público, MSSQLSERVERDISTRIBUTOR. Para obter mais informações sobre os objetos criados no banco de dados Oracle, consulte Objetos criados no Editor Oracle.

ObservaçãoObservação

Ao descartar o sinônimo público MSSQLSERVERDISTRIBUTOR e o usuário de replicação Oracle configurado com a opção CASCADE irá remover todos os objetos de replicação do Publicador Oracle.

Um script de amostra foi fornecido para ajudar na instalação do esquema de usuário de replicação Oracle. O script está disponível no seguinte diretório após a instalação do SQL Server: <unidade>:\\Arquivos de Programas\Microsoft SQL Server\<Nome_da_instância>\MSSQL\Install\oracleadmin.sql. <unidade>:\\Arquivos de Programa\Microsoft SQL Server\<InstanceName>\MSSQL\Install\oracleadmin.sql. Também está incluído no tópico Script para conceder permissões da Oracle.

Conecte-se ao banco de dados Oracle usando uma conta com privilégios DBA e execute o script. Os prompts de script do usuário e senha para o esquema de usuário administrativo de replicação, assim como o espaço de tabela padrão, no qual os objetos serão criados (o espaço de tabela já deve existir no banco de dados Oracle). Para obter mais informações sobre como especificar outros espaços de tabela para objetos, consulte Gerenciando espaços de tabela Oracle. Escolha um nome de usuário e uma senha forte e anote ambas as informações, pois serão solicitadas depois que o banco de dados Oracle estiver configurado como um Publicador. É recomendado que o esquema seja usado apenas para objetos exigidos pelo aplicativo, não crie tabelas para serem publicadas nesse esquema.

Criando manualmente o esquema de usuário

Se você criar manualmente o esquema de usuário de replicação, é necessário conceder ao esquema as permissões a seguir, diretamente ou através de uma função de banco de dados.

  • CREATE PUBLIC SYNONYM e DROP PUBLIC SYNONYM

  • CREATE PROCEDURE

  • CREATE SEQUENCE

  • CREATE SESSION

Também será necessário conceder as seguintes permissões ao usuário diretamente (não por uma função):

  • CREATE ANY TRIGGER. Essa é exigida apenas para replicação de transação pois a replicação de instantâneo não usa gatilhos.

  • CREATE TABLE

  • CREATE VIEW

Instalando e configurando o software de rede cliente Oracle no SQL Server Distributor

Você deve instalar e configurar o software de rede cliente Oracle e o provedor Oracle OLE DB no SQL Server Distributor, para que o Distributor possa fazer as conexões com o Publicador Oracle. Após instalar o software, defina as permissões adequadas nas pastas onde o software está instalado, e então, pare e reinicie a instância SQL Server para garantir que todas as instâncias serão atualizadas (as permissões serão descritas a seguir, na seção "Definindo permissões de diretório").

ObservaçãoObservação

O cliente de rede cliente Oracle deve ser a versão mais recente disponível. A Oracle recomenda que os usuários instalem as versões mais recentes do software cliente. O software cliente é, freqüentemente, uma versão mais recente do que o software do banco de dados.

A maneira mais prática para instalar e configurar o software de rede cliente, é usar o Oracle Universal Installer e o Net Configuration Assistant nos disco do Oracle Client.

No Oracle Universal Installer, você irá fornecer as seguintes informações:

Informações

Descrição

Oracle Home

Esse é o caminho para diretório de instalação do software Oracle. Aceite o padrão (C:\oracle\ora90 ou semelhante) ou digite outro caminho. Para obter mais informações sobre o Oracle Home, consulte a seção "Considerações sobre o Oracle Home" mais adiante neste tópico.

Nome do Oracle home

Um alias para o caminho do Oracle home.

Tipo de instalação

No Oracle 10g, selecione a opção de instalação Administrador.

Depois que o Oracle Universal Installer estiver completo, use o Net Configuration Assistant para configurar a conectividade de rede. Você deve fornecer quatro informações para configurar a conectividade de rede. O administrador do banco de dados Oracle configura a configuração de rede quando define o banco de dados e o ouvinte e, se você não tiver essas informações, elas deverão ser fornecidas pelo administrador. Você deve fazer o seguinte:

Ação

Descrição

Identificar o banco de dados.

Há dois métodos para identificar o banco de dados. O primeiro método usa o Sistema Identificador Oracle (SID) e está disponível em todas as versões do Oracle. O segundo método usa o Nome do Serviço que está disponível pelo Oracle versão 8.0. Ambos os métodos usam um valor que é configurado quando o banco de dados é criado, e é importante que a configuração de rede cliente use o mesmo método de nomenclatura que o administrador usou ao configurar o ouvinte para o banco de dados.

Identifique um alias de rede para o banco de dados

Você deve especificar um alias de rede que é usado para acessar o banco de dados Oracle. Você também fornece esse alias quando identifica o banco de dados Oracle como um Publicador no SQL Server Distributor. O alias de rede é, essencialmente, um ponteiro para o SID remoto ou Nome do Serviço configurado quando o banco de dados foi criado e foi referido por diversos nomes em diferentes versões e produtos Oracle, incluindo o Net Service Name e o TNS Alias. O SQL*Plus solicita esse alias como o parâmetro "Cadeia de caracteres de Host" ao efetuar logon.

Selecione o protocolo de rede

Selecione os protocolos apropriados que você gostaria de ter suporte. A maioria dos aplicativos usa o TCP.

Especifique a informações de host para identificar o ouvinte de banco de dados

O host é o nome ou alias do DNS do computador no qual o ouvinte Oracle está sendo executado e que, geralmente, é o mesmo computador no qual o banco de dados está localizado. Para alguns protocolos, você deve fornecer informações adicionais. Por exemplo, se você selecionar TCP será necessário fornecer a porta na qual o ouvinte está escutando as solicitações de conexão para o banco de dados de destino. A configuração de TCP padrão usa a porta 1521.

Definindo permissões de diretório

A conta sob a qual o serviço SQL Server no Distributor executa, deve receber permissões de gravação e leitura para o diretório (e todos os subdiretórios) no qual o software de rede cliente Oracle está instalado.

Testando conectividade entre o SQL Server Distributor e o Publicador Oracle

Quando estiver concluindo o Net Configuration Assistant deverá existir uma opção que irá testar a conexão do Publicador Oracle. Antes de você testar a conexão, certifique-se de que a instância do banco de dados Oracle está online e que o Oracle Listener está sendo executado. Se o teste não for bem sucedido, contate o responsável pelo Oracle DBA para o banco de dados ao qual você está tentando se conectar.

Após você ter feito uma conexão bem sucedida com o Publicador Oracle tente fazer logon no banco de dados, usando a conta e senha associadas com o esquema de usuário administrativo de replicação que você criou. Enquanto estiver executando na mesma conta do Windows que o serviço SQL Server usa, realize o seguinte:

  1. Clique em Iniciar e em Executar.

  2. Digite cmd e clique em OK.

  3. No prompt de comando, digite:

    sqlplus <UserSchemaLogin>/<UserSchemaPassword>@<NetServiceName>

    Por exemplo: sqlplus replication/$tr0ngPasswerd@Oracle90Server

  4. Se a configuração de rede foi bem sucedida, o logon terá êxito e um prompt SQL será exibido.

  5. Se você enfrentar problemas ao se conectar com o banco de dados Oracle, consulte a seção "O SQL Server Distributor não pode se conectar à instância do banco de dados Oracle" em Solucionando problemas de Editores Oracle.

Considerações sobre o Oracle Home

O Oracle oferece suporte à instalação lado a lado de binários aplicativos, mas apenas um conjunto de binários pode ser usado por replicação em um determinado momento. Cada conjunto de binários é associado a um Oracle Home; os binários estão no diretório %ORACLE_HOME%\bin. É necessário certificar-se de que o conjunto correto de binários (especificamente a versão mais recente do software de rede cliente) seja usado quando a replicação fizer as conexões com o Publicador Oracle.

Efetue logon no Distribuidor com as contas usadas pelo serviço SQL Server e o serviço Agent SQL Server e defina as variáveis de ambiente apropriadas. A variável %ORACLE_HOME% deve ser definida para fazer referência ao ponto de instalação que você especificou na instalação do software de rede cliente. O %PATH% deve incluir o diretório %ORACLE_HOME% \bin como a primeira entrada Oracle que for encontrada. Para obter mais informações sobre como definir as variáveis de ambiente, consulte a documentação do Windows.

Configurando o banco de dados Oracle como um Publicador no SQL Server Distributor

Editores Oracle sempre usam um Distribuidor remoto e é necessário configurar uma instância do SQL Server para agir como um Distribuidor para o Publicador Oracle (um Publicador Oracle pode usar apenas um Distribuidor mas, um único Distribuidor pode efetuar serviços em mais de um Publicador Oracle). Após configurar um Distribuidor, identifique a instância do banco de dados Oracle como sendo um Publicador no Distribuidor SQL Server através do SQL Server Management Studio, Transact-SQL ou do RMO (Replication Management Objects). Para obter mais informações sobre como configurar um Distribuidor, consulte Configurando a distribuição.

ObservaçãoObservação

Um Publicador Oracle não pode ter o mesmo nome do Distribuidor SQL Server ou o mesmo nome de um dos Editores SQL Server, usando o mesmo Distribuidor.

Quando você identifica o banco de dados Oracle como sendo um Publicador, é necessário escolher uma opção de edição Oracle: Completa ou Oracle Gateway. Após a identificação de um Publicador, essa opção não poderá ser alterada se você não descartar e reconfigurar o Publicador. A opção Completa é projetada para fornecer instantâneos e publicações transacionais 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.

Após o Publicador Oracle ser identificado no Distribuidor SQL Server, a replicação cria um servidor vinculado com o mesmo nome como o nome do serviço TNS do banco de dados Oracle. Esse servidor vinculado só pode ser usado por replicação. Se você precisa conectar-se ao Publicador Oracle sobre uma conexão de servidor vinculado, crie outro nome do serviço TNS e use esse nome ao chamar sp_addlinkedserver (Transact-SQL).

Para configurar um Publicador Oracle e criar uma publicação