Exchange Server Active Manager
Microsoft Exchange Server inclui um componente chamado Active Manager que gerencia a plataforma de alta disponibilidade que inclui o DAG (grupo de disponibilidade de banco de dados) e cópias do banco de dados de caixa de correio. O Active Manager é executado dentro do Serviço de Replicação do Microsoft Exchange (MSExchangeRepl.exe) em todos os servidores de Caixa de Correio. Em servidores de Caixa de Correio que não são membros de um DAG, há uma única função do Active Manager: Active Manager Autônomo.
Em servidores que são membros de um DAG, há duas funções do Active Manager: Active Manager Principal (PAM) e Active Manager em Espera (SAM). PAM é a função do Active Manager em um DAG que decide quais cópias serão ativas e passivas. O PAM é responsável por obter notificações de alteração de topologia e reagir a falhas do servidor. O membro do DAG que hospeda a função PAM é sempre o membro que atualmente possui o recurso de quorum do cluster (grupo de cluster padrão). Se o servidor que possui o recurso de quorum do cluster falhar, a função PAM automaticamente é movida para um servidor sobrevivente, que se apropria do recurso de quorum do cluster. Além disso, se for preciso desligar o servidor que hospeda o recurso de quorum do cluster para manutenção ou atualização, você deve primeiro mover o PAM para outro servidor do DAG. O PAM controla todos os movimentos das designações ativas entre uma cópia de banco de dados. (Somente uma cópia pode estar ativa em um horário especificado, e essa cópia pode estar montada ou desmontada.) O PAM também executa as funções da função SAM no sistema local (detectando o banco de dados local e falhas do Armazenamento de Informações).
O SAM fornece informações sobre qual servidor hospeda a cópia ativa de um banco de dados de caixa de correio para outros componentes do Exchange que estão executando um componente cliente do Active Manager (por exemplo, os serviços de Acesso para Cliente ou de Transporte). O SAM detecta falhas de bancos de dados locais e do Armazenamento de Informações local. Ele reage a falhas pedido ao PAM que inicie um failover (caso o banco de dados seja replicado). Um SAM não determina o destino de um failover, nem atualiza o estado da localização do banco de dados no PAM. Ele acessará o estado da localização da cópia do banco de dados ativa para responder consultas na cópia ativa do banco de dados que recebe.
Observação
Exchange Server não é um aplicativo clusterizado. Ao invés disso, usa as funções da biblioteca do cluster implementadas na clusapi.dll para cluster, rede de cluster (pulsação), gerenciamento de nó, registro de cluster e algumas funções de código de controle. Além disso, o Active Manager armazena informações do banco de dados de caixa de correio atual (por exemplo, dados ativos e passivos e dados montados) no banco de dados de cluster (também conhecido como o registro de cluster). Embora as informações sejam armazenadas diretamente no banco de dados de cluster, não são acessadas diretamente por qualquer outro componente.
Em Exchange Server, o serviço de Replicação do Microsoft Exchange monitora periodicamente a integridade de todos os bancos de dados montados. Além disso, ele também monitora o Mecanismo de Armazenamento Extensível (ESE) para detectar qualquer erro ou falha de E/S. Quando o serviço detecta uma falha, o Active Manager é notificado. O Active Manager então determina qual cópia de banco de dados deve ser montada e o que é necessário para montar o banco de dados. Além disso, ele rastreia a cópia ativa de um banco de dados de caixa de correio (com base na última cópia montada do banco de dados) e fornece as informações de resultados de acompanhamento aos serviços de Acesso ao Cliente no servidor da caixa de correio ao qual o cliente está conectado.
Seleção de melhor cópia
Quando ocorre uma falha que impede o acesso à cópia ativa de um banco de dados de caixa de correio replicado, o Active Manager seleciona a melhor cópia passiva possível do banco de dados afetado a ser ativada. Esse processo era conhecido como BCS (melhor seleção de cópia) em versões anteriores do Exchange e, no Exchange 2016 e no Exchange 2019, é conhecido como a melhor seleção de cópia e servidor (BCSS). O processo geral ocorre na seguinte ordem:
A Disponibilidade Gerenciada ou o Active Manager detecta uma falha, ou um administrador inicia uma alternância sem destino.
O PAM executa o algoritmo interno de BCSS.
Ocorre um processo chamado tentativa de cópia de últimos logs (ACLL), que tenta copiar os arquivos de log ausentes do servidor que hospedava a cópia do banco de dados ativa antes da falha ou da alternância.
Quando o processo ACLL tiver sido concluído, o valor de AutoDatabaseMountDial para os servidores de Caixa de Correio que hospedam cópias do banco de dados é comparado com o tamanho da fila de cópia sendo ativada. Nesse momento:
O número de arquivos de log faltando é menor ou igual ao valor do AutoDatabaseMountDial, caso em que a Etapa 5 ocorre.
O número dos arquivos de log faltando é maior que o valor de AutoDatabaseMountDial, situação em que o Active Manager tentará ativar a próxima melhor cópia disponível, se houver uma.
O PAM emite uma solicitação de montagem para o Repositório de Informações do Microsoft Exchange por meio de RPC (chamada de procedimento remoto). Nesse momento:
O banco de dados é montado e disponibilizado para clientes.
O banco de dados não é montado e o PAM executa as etapas 3 e 4 na próxima melhor cópia (caso alguma esteja disponível).
Em versões anteriores do Exchange, o processo BCS avaliou vários aspectos de cada cópia de banco de dados para determinar a melhor cópia a ser ativada. Isso incluía:
Comprimento da fila de cópia
Comprimento da fila de repetição
Status do banco de dados
Status do índice de conteúdo
Em Exchange Server, o Active Manager percorre todas as mesmas verificações e fases do BCS, mas agora também inclui o uso de uma restrição da ordem decrescente dos estados de saúde. Especificamente, o BCSS inclui várias novas verificações de integridade que fazem parte dos componentes internos de monitoramento de disponibilidade gerenciada no Exchange Server. Há quatro verificações adicionais executadas pelo Active Manager (listadas na ordem em que são executadas):
All Healthy: verifica se um servidor hospeda uma cópia do banco de dados afetado que tem todos os componentes de monitoramento em um estado íntegro.
Até Normal Healthy: verifica se um servidor hospeda uma cópia do banco de dados afetado que tem todos os componentes de monitoramento com prioridade normal em um estado saudável.
Tudo melhor que a origem: verifica se um servidor hospeda uma cópia do banco de dados afetado que tem componentes de monitoramento em um estado melhor do que o servidor atual que hospeda a cópia afetada.
O mesmo que o Source: verifica se um servidor hospeda uma cópia do banco de dados afetado que tem componentes de monitoramento em um estado que é o mesmo que o servidor atual que hospeda a cópia afetada.
Se a BCSS for chamada como um resultado de um failover disparado por um componente de monitoramento (por exemplo, por meio de um respondente de Failover), uma restrição obrigatória adicional será aplicada onde a integridade de componentes do servidor de destino deve ser melhor que o servidor em que o failover ocorreu. Por exemplo, se uma falha de Outlook na Web disparar um failover por meio de um respondente de Failover, o BCSS deverá selecionar um servidor que hospeda uma cópia do banco de dados afetado no qual Outlook na Web está saudável.
Processo de seleção de melhor cópia
Em relação a falhas de banco de dados (não falhas de protocolo), o Active Manager inicia o melhor processo de seleção de cópia criando uma lista de cópias de banco de dados que são potenciais candidatos à ativação. Cópias de banco de dados que estejam inacessíveis ou bloqueadas administrativamente contra ativação são ignoradas e não são usadas durante o processo de seleção. A ordem da lista depende do valor de AutoDatabaseMountDial:
Se o AutoDatabaseMountDial estiver configurado com qualquer valor diferente de
Lossless
todos os servidores que hospedam uma cópia do banco de dados, o Active Manager classificará a lista resultante usando o comprimento da fila de cópia como a chave primária. O cálculo é baseado em LastLogInspected (do ponto de vista da cópia), para que a lista de cópias possíveis seja classificada pelo valor mais alto para LastLogInspected (que será a cópia com o menor comprimento de fila de cópia). Se necessário, o Active Manager classifica a lista uma segunda vez, usando o valor da Preferência de Ativação como uma chave secundária para desvincular quaisquer condições em que duas ou mais cópias passivas têm o mesmo comprimento da fila de cópia. A cópia com o menor valor de Preferência de Ativação possui a mais alta prioridade na lista.Se o AutoDatabaseMountDial estiver configurado com um valor de
Lossless
em qualquer servidor que hospeda uma cópia do banco de dados, o Active Manager classificará a lista resultante em ordem crescente usando o valor para a preferência de ativação como a chave primária. Além disso, quando um administrador realiza uma alternância de servidor ou de banco de dados sem perdas sem especificar um destino, o Active Manager também classifica a lista resultante em ordem crescente usando o valor de Preferência de Ativação com chave primária.
Em seguida, o Active Manager tenta localizar na lista uma cópia do banco de dados de caixa de correio com status Healthy, DisconnectedAndHealthy, DisconnectedAndResynchronizing ou SeedingSource e avalia o potencial de ativação de cada uma das cópias na lista usando um conjunto ordenado de dez critérios. O Active Manager determina se qualquer dos candidatos para ativação atende ao primeiro conjunto de critérios:
Tem um índice de conteúdo com o status Íntegro (Healthy).
Tem um tamanho de fila de cópia inferior a 10 arquivos de log.
Tem um tamanho de fila de repetição inferior a 50 arquivos de log.
Se nenhuma das cópias do banco de dados atender ao primeiro conjunto de critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao segundo conjunto de critérios:
Tem um índice de conteúdo com o status Rastreando (Crawling).
Tem um tamanho de fila de cópia inferior a 10 arquivos de log.
Tem um tamanho de fila de repetição inferior a 50 arquivos de log.
Se nenhuma das cópias do banco de dados atender ao segundo conjunto de critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao terceiro conjunto de critérios:
Tem um índice de conteúdo com o status Íntegro (Healthy).
Tem um tamanho de fila de repetição inferior a 50 arquivos de log.
Se nenhuma das cópias do banco de dados atender ao terceiro conjunto de critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao quarto conjunto de critérios:
Tem um índice de conteúdo com o status Rastreando (Crawling).
Tem um tamanho de fila de repetição inferior a 50 arquivos de log.
Se nenhuma das cópias do banco de dados atender ao quarto conjunto de critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao quinto conjunto de critérios:
- Tem um tamanho de fila de repetição inferior a 50 arquivos de log.
Se nenhuma das cópias do banco de dados atender ao quinto conjunto de critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao sexto conjunto de critérios:
Tem um índice de conteúdo com o status Íntegro (Healthy).
Tem um tamanho de fila de cópia inferior a 10 arquivos de log.
Se nenhuma das cópias do banco de dados atender aos sextos critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao sétimo conjunto de critérios:
Tem um índice de conteúdo com o status Rastreando (Crawling).
Tem um tamanho de fila de cópia inferior a 10 arquivos de log.
Se nenhuma das cópias do banco de dados atender ao sétimo conjunto de critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao oitavo conjunto de critérios:
- Tem um índice de conteúdo com o status Íntegro (Healthy).
Se nenhuma das cópias do banco de dados atender a todo o oitavo conjunto de critérios, o Active Manager tentará localizar uma cópia de banco de dados que atenda ao nono conjunto de critérios:
- Tem um índice de conteúdo com o status Rastreando (Crawling).
Se nenhuma das cópias do banco de dados atender ao nono conjunto de critérios, o Active Manager tentará ativar qualquer cópia de banco de dados com um status de Healthy, DisconnectedAndHealthy, DisconnectedAndResynchronizing ou SeedingSource (o décimo conjunto de critérios). Se nenhuma cópia de banco de dados que atenda ao décimo conjunto de critérios for encontrada, não será possível ativar automaticamente uma cópia do banco de dados.
Depois que uma ou mais cópias são localizadas que atendem a um ou mais conjuntos de critérios, o processo ACLL copia todos os arquivos de log da origem original para a nova cópia ativa em potencial. Depois que o processo ACLL for concluído, o PAM emite uma solicitação de montagem e o banco de dados é montado e disponibilizado para clientes ou o banco de dados não é montado e o PAM pesquisa a próxima melhor cópia (se uma estiver disponível).