Minimizar o tempo de inatividade de bancos de dados espelhados ao atualizar instâncias do servidor

Ao atualizar instâncias do servidor do SQL Server 2005 ou do SQL Server 2008 para o SQL Server 2012, você pode reduzir o tempo de inatividade de cada banco de dados espelho para apenas um único failover manual com uma atualização em sequência, conhecida como atualização sem interrupção. Uma atualização sem-interrupção consiste em um processo de várias etapas que, em sua forma mais simples, envolve atualizar a instância do servidor que funciona como o servidor espelho de uma sessão de espelhamento, executar o failover manual no banco de dados espelho, atualizar o antigo servidor principal e continuar o espelhamento. Na prática, o processo exato dependerá do modo de operação e do número e do layout de sessões de espelhamento em execução nas instâncias do servidor que você está atualizando.

ObservaçãoObservação

Para obter informações sobre como executar uma atualização sem-interrupção para instalar um service pack ou hotfix, consulte Instalar um service pack em um sistema com tempo de inatividade mínimo para bancos de dados espelhados.

Preparação recomendada (práticas recomendadas)

Antes de iniciar uma atualização sem-interrupção, é recomendável:

  1. Executar um failover manual em pelo menos uma das sessões de espelhamento:

    ObservaçãoObservação

    Para obter informações sobre o funcionamento do failover manual, consulte Troca de função durante uma sessão de espelhamento de banco de dados (SQL Server).

  2. Proteger seus dados:

    1. Executar um backup de banco de dados completo em todos os bancos de dados principais:

      Criar um backup completo de banco de dados (SQL Server).

    2. Execute o comando DBCC CHECKDB em todos os bancos de dados principais.

Etapas da atualização sem-interrupção

As etapas específicas de uma atualização sem-interrupção dependem do modo de operação da configuração de espelhamento. No entanto, as etapas básicas são as mesmas.

ObservaçãoObservação

Para obter informações sobre os modos de operação, consulte Modos de operação de espelhamento de banco de dados.

A ilustração a seguir é um fluxograma que mostra as etapas básicas de uma atualização sem-interrupção para cada modo de operação. Os procedimentos correspondentes estão descritos após a ilustração.

Fluxograma mostrando as etapas de uma atualização de rolagem

Observação importanteImportante

Uma instância de servidor pode estar executando diferentes funções de espelhamento (servidor principal, servidor espelho ou testemunha) em sessões de espelhamento simultâneas. Nesse caso, você terá de adaptar o processo básico de atualização sem-interrupção. Para obter mais informações, consulte Troca de função durante uma sessão de espelhamento de banco de dados (SQL Server).

Para alterar uma sessão em modo de alto desempenho para modo de segurança alta

Para remover uma testemunha de uma sessão

Para executar a atualização sem-interrupção

  1. Para minimizar o tempo de inatividade, recomendamos o seguinte: inicie a atualização sem-interrupção atualizando qualquer parceiro de espelhamento que no momento seja o servidor espelho em todas as suas sessões de espelhamento. Pode ser necessário atualizar várias instâncias do servidor neste momento.

    ObservaçãoObservação

    Uma testemunha pode ser atualizada em qualquer ponto do processo de atualização sem-interrupção. Por exemplo, se uma instância do servidor for um servidor espelho na Sessão 1 e for uma testemunha na Sessão 2, será possível atualizar a instância do servidor agora.

    A instância de servidor a ser atualizada primeiro depende da configuração atual das sessões de espelhamento, como segue:

    • Se qualquer instância de servidor já for o servidor espelho em todas as suas sessões de espelhamento, atualize a instância de servidor para a nova versão.

    • Se todas as instâncias de servidor forem atualmente o servidor principal em quaisquer sessões de espelhamento, selecione uma instância de servidor para atualizar primeiro. Em seguida, execute manualmente um failover em cada um de seus bancos de dados principais e atualize essa instância de servidor.

    Depois de ser atualizada, uma instância de servidor retoma automaticamente cada uma de suas sessões de espelhamento.

  2. Para cada sessão de espelhamento cuja instância de servidor espelho acabou de ser atualizada, espere que a sessão seja sincronizada. Depois, conecte-se à instância do servidor principal e execute o failover manual na sessão. Em failover, a instância do servidor atualizada torna-se o servidor principal para aquela sessão e o servidor principal anterior torna-se o servidor espelho.

    O objetivo desta etapa é que outra instância de servidor se torne o servidor espelho em cada sessão de espelhamento na qual é um parceiro.

    Restrições depois da execução de failover para uma instância de servidor atualizada.

    Depois de executar failover de uma instância de servidor do SQL Server 2005 ou do SQL Server 2008 para um SQL Server 2012, a sessão de banco de dados é suspensa. Ela não pode ser retomada até que o outro parceiro seja atualizado. Porém, o servidor principal ainda aceita conexões e permite acesso a dados e modificações no banco de dados principal.

    ObservaçãoObservação

    O estabelecimento de uma nova sessão de espelhamento exige que todas as instâncias de servidor estejam executando a mesma versão do SQL Server.

  3. Depois de executar failover, é recomendável executar o comando DBCC CHECKDB no banco de dados principal.

  4. Atualize cada instância de servidor que seja agora o servidor espelho em todas as sessões de espelhamento nas quais é um parceiro. Talvez seja necessário atualizar servidores múltiplos nesse momento.

    Observação importanteImportante

    Em uma configuração de espelhamento complexa, algumas instâncias do servidor podem ainda ser o servidor principal original em uma ou mais sessões de espelhamento. Repita as etapas 2 a 4 para essas instâncias do servidor até que todas as instâncias envolvidas sejam atualizadas.

  5. Continue a sessão de espelhamento.

    ObservaçãoObservação

    O failover automático não funcionará até que a testemunha tenha sido atualizada e novamente adicionada à sessão de espelhamento.

  6. Atualize qualquer instância de servidor restante que seja a testemunha em todas as suas sessões de espelhamento. Depois que uma testemunha atualizada voltar a uma sessão de espelhamento, o failover automático torna-se possível novamente. Pode necessário atualizar vários servidores nesse momento.

Para retornar a uma sessão em modo de alto desempenho

  • Opcionalmente, retorne ao modo de alto desempenho usando um dos seguintes métodos:

    • No SQL Server Management Studio: altere a opção Modo de operação para Alto desempenho (assíncrono) por meio da Página Espelhamento da caixa de diálogo Propriedades do Banco de Dados.

    • No Transact-SQL: use ALTER DATABASE para definir a segurança de transações como OFF.

Para adicionar uma testemunha de volta a uma sessão de espelhamento

Consulte também

Tarefas

Exibir o estado de um banco de dados espelho (SQL Server Management Studio)

Instalar um service pack em um sistema com tempo de inatividade mínimo para bancos de dados espelhados

Forçar serviço em uma sessão de espelhamento de banco de dados (Transact-SQL)

Iniciar o Monitor de Espelhamento de Banco de Dados (SQL Server Management Studio)

Referência

espelhamento de banco de dados ALTER DATABASE (Transact-SQL)

BACKUP (Transact-SQL)

Conceitos

Espelhamento de banco de dados (SQL Server)

Troca de função durante uma sessão de espelhamento de banco de dados (SQL Server)

Modos de operação de espelhamento de banco de dados