Atualmente a disponibilidade dos dados para uma empresa pode estar diretamente relacionada ao seu sucesso ou fracasso, ao fechamento de um novo negócio, à perda de um contrato, ao lucro ou ao prejuízo, e até mesmo a perdas intangíveis. Dessa forma, devido à grande necessidade de mitigar e tornar o mais transparente possível as quedas que possam vir a ocorrer em ambientes de produção, as empresas vêm investindo cada vez mais em recursos de alta disponibilidade visando a contingência e continuidade de seu negócio.
Uma das principais responsabilidades de um administrador de banco de dados é garantir a disponibilidade das bases de dados que estão sob sua administração, traçando e implementando estratégias para que isso seja possível de ser realizado dentro de suas instâncias de banco de dados SQL Server.
Para esse tipo de cenário, o SQL Server disponibiliza diversas soluções de alta disponibilidade, entre elas o Log Shipping, que pode ser um grande aliado do administrador de banco de dados no cumprimento dessa missão crítica.
A fim de facilitar o entendimento sobre o Log Shipping, este artigo apresentará suas principais características e utilizações, expondo-o de maneira prática e teórica.
Log Shipping
O Log Shipping é uma solução de alta disponibilidade encontrada em diversas versões do SQL Server que permite o envio de backups de log de transações de um banco para um ou mais bancos secundários em instâncias diferentes de servidor secundário.
Essa solução consiste em três operações:
- Realização do backup de log de transações na instância do servidor primário;
- Cópia do arquivo de backup para o servidor secundário;
- Restauração do backup de log na instância do servidor secundário.
Além da utilização para propor um ambiente de alta disponibilidade, o Log Shipping pode ainda ser utilizado para oferecer uma base de dados para geração de relatórios, por exemplo, direcionando as aplicações que realizam esse tipo de processamento para a base de dados secundária (isso pode evitar que possíveis problemas de desempenho venham a ocorrer no ambiente de produção). Entretanto, devido à diferença de tempo entre as realizações e restaurações dos backups de log de transações, os dados terão uma diferença de conteúdo entre uma base e outra, além disso, durante os processos de restauração, a base de dados secundária ficará indisponível para consultas.
Essa diferença de dados entre as bases de dados primária e secundária também pode ser utilizada positivamente, por exemplo, se algum dado for acidentalmente modificado na base de dados primária e o problema for rapidamente identificado, o atraso de dados entre backup e restauração pode lhe proporcionar uma forma de recuperação das informações antes que as alterações sejam enviadas para a base secundária.
Servidor e banco de dados primário ...