Monitore programaticamente a replicação
O Replication Monitor é uma ferramenta gráfica que permite monitorar uma topologia de replicação. Você pode acessar os mesmos dados de monitoramento programaticamente usando procedimentos armazenados de replicação Transact-SQL ou RMO (objetos de gerenciamento de replicação). Esses objetos permitem programar as seguintes tarefas:
Monitorar o estado de Publicadores, publicações e assinaturas.
Monitorar as sessões do Merge Agent em um ou mais Assinantes.
Monitorar os comandos transacionais que estão esperando para serem aplicados em um ou mais Assinantes.
Definir os limites métricos que determinam quando uma publicação requer intervenção.
Monitorar o estado de tokens de rastreamento.
Neste tópico:
RMO (Replication Management Objects)
Transact-SQL
Para monitorar Publicador, publicações e assinatura a partir do Distribuidor
No Distribuidor, no banco de dados de distribuição, execute sp_replmonitorhelppublisher. Isso retornará informações para todos os Publicadores que usarem esse Distribuidor. Para limitar o conjunto de resultados a um único Publicador, especifique @publisher.
No Distribuidor do banco de dados de distribuição, execute sp_replmonitorhelppublication. Isso retornará informações para todas as publicações que usarem esse Distribuidor. Para limitar o conjunto de resultados a um único Publicador, publicação ou banco de dados publicado, especifique @publisher, @publication ou @publisher_db, respectivamente.
No Distribuidor do banco de dados de distribuição, execute sp_replmonitorhelpsubscription. Isso retornará informações para todas as assinaturas que usarem esse Distribuidor. Para limitar o conjunto de resultados a assinaturas pertencentes a um único Publicador, publicação ou banco de dados publicado, especifique @publisher, @publication ou @publisher_db, respectivamente.
Para monitorar os comandos transacionais que estão esperando para serem aplicados no Assinante.
- No Distribuidor do banco de dados de distribuição, execute sp_replmonitorsubscriptionpendingcmds. Isso retornará informações de monitoração para todos os comandos pendentes, de todas as assinaturas que usam esse Distribuidor. Para limitar o conjunto de resultados a comandos pendentes para assinaturas pertencentes a um único Publicador, Assinante, publicação ou banco de dados publicado, especifique @publisher, @subscriber, @publication ou @publisher_db, respectivamente.
Para monitorar as alterações de mesclagem a espera de serem carregadas ou baixadas
No Publicador do banco de dados de publicação, execute sp_showpendingchanges. Isso retornará um conjunto de resultados que mostra informações sobre as alterações esperando para ser replicadas nos Assinantes. Para limitar o conjunto de resultados a alterações que pertencem a uma única publicação ou artigo, especifique @publication ou @article, respectivamente.
Em um Assinante, no banco de dados da assinatura, execute sp_showpendingchanges. Isso retornará um conjunto de resultados que mostra informações sobre as alterações esperando para ser replicadas no Publicador. Para limitar o conjunto de resultados a alterações que pertencem a uma única publicação ou artigo, especifique @publication ou @article, respectivamente.
Para monitorar sessões do Merge Agent
No Distribuidor do banco de dados de distribuição, execute sp_replmonitorhelpmergesession. Isso retornará informações de monitoração, inclusive Session_id, em todas as sessões do Merge Agent de todas as assinaturas que usam esse Distribuidor. Você também pode obter o Session_id consultando a tabela do sistema MSmerge_sessions .
No Distribuidor, no banco de dados de distribuição, execute sp_replmonitorhelpmergesession. Especifique um valor de Session_id da etapa 1 para @session_id. Isso exibirá informações de monitoramento detalhadas sobre a sessão.
Repita a etapa 2 para cada sessão que interessar.
Para monitorar sessões do Merge Agent para assinatura pull do Assinante
No Assinante, no banco de dados da assinatura, execute sp_replmonitorhelpmergesession. Para uma determinada assinatura, especifique @publisher, @publication e o nome do banco de dados de publicação para @publisher_db. Isso retornará informações de monitoração das últimas cinco sessões do Merge Agent para essa assinatura. Observe que o valor de Session_id para as sessões que interessarem, no conjunto de resultados.
No Assinante, no banco de dados da assinatura, execute sp_replmonitorhelpmergesessiondetail. Especifique um valor de Session_id da etapa 1 para @session_id. Isso exibirá informações de monitoramento detalhadas sobre a sessão.
Repita a etapa 2 para cada sessão que interessar.
Para exibir e modificar as métricas de limite do monitor para uma publicação
No Distribuidor, no banco de dados de distribuição, execute sp_replmonitorhelppublicationthresholds. Isso retornará o conjunto de limites de monitoramento, para todas as publicações que usam esse Distribuidor. Para limitar o conjunto de resultados para monitorar limites para publicações pertencentes a um único Publicador ou banco de dados publicado ou a uma única publicação, especifique @publisher, @publisher_db ou @publication, respectivamente. Observe o valor de Metric_id para qualquer limite que deva ser alterado. Para obter mais informações, consulte Set Thresholds and Warnings in Replication Monitor.
No Distribuidor, no banco de dados de distribuição, execute sp_replmonitorchangepublicationthreshold. Especifique o seguinte, quando necessário:
O valor Metric_id obtido na etapa 1 para @metric_id.
Um novo valor para a métrica de limite do monitor para @value.
Um valor de 1 para @shouldalert para que um alerta seja registrado quando esse limite for atingido ou um valor de 0 se um alerta não for necessário.
Um valor de 1 para @mode para habilitar a métrica de limite do monitor ou um valor de 2 para desabilitá-la.
RMO (Replication Management Objects)
Para monitorar uma assinatura para uma publicação de mesclagem no Assinante
Crie uma conexão com o Assinante usando a classe ServerConnection .
Crie uma instância da classe MergeSubscriberMonitor e defina as propriedades Publisher, Publication, PublisherDB, SubscriberDB para a assinatura, e defina a propriedade ConnectionContext como ServerConnection criado na etapa 1.
Chame um dos métodos seguintes para retornar informações sobre as sessões do Merge Agent para essa assinatura:
GetSessionsSummary - retorna uma matriz de objetos MergeSessionSummary com informações até as últimas cinco sessões do Merge Agent. Observe o valor SessionId para qualquer sessão do seu interesse.
GetSessionsSummary - retorna uma matriz de objetos MergeSessionSummary com informações das sessões do Merge Agent que ocorreram durante o número de horas passadas no parâmetro hours (até as últimas cinco sessões). Observe o valor SessionId para qualquer sessão do seu interesse.
GetLastSessionSummary - retorna um objeto MergeSessionSummary com informações sobre a última sessão do Merge Agent. Observe o valor de SessionId para esta sessão.
GetSessionsSummaryDataSet - retorna uma matriz de objetos DataSet com informações até as últimas cinco sessões do Merge Agent, uma em cada linha. Observe o valor da coluna Session_id para qualquer sessão do seu interesse.
GetLastSessionSummaryDataRow - retorna um objeto DataRow com informações sobre a última sessão do Merge Agent. Observe o valor da coluna Session_id para essa sessão.
(Opcional) Chame o RefreshSessionSummary para atualizar os dados para o objeto MergeSessionSummary passado como mss, ou chame RefreshSessionSummary para atualizar os dados no objeto DataRow passado como drRefresh.
Usando a id de sessão obtida na etapa 3, chame um dos métodos seguintes para retornar informações sobre os detalhes de uma sessão em particular:
GetSessionDetails – retorna uma matriz de MergeSessionDetail objetos para a sessionID fornecida.
GetSessionDetailsDataSet – retorna um DataSet objeto com informações para a sessionID especificada.
Para monitorar as propriedades de replicação para todas as publicações em um Distribuidor
Crie uma conexão com o Distribuidor usando a classe ServerConnection .
Criar uma instância da classe ReplicationMonitor.
Defina a propriedade ConnectionContext como ServerConnection criada na etapa 1.
Chame o método LoadProperties para obter as propriedades do objeto.
Execute um ou mais dos métodos seguintes para retornar informações de replicação para todos os Publicador que usam esse Distribuidor.
EnumDistributionAgents - retorna um objeto DataSet que contém informações sobre todos os Distribution Agents nesse Distribuidor.
EnumErrorRecords - retorna um objeto DataSet que contém informações sobre os erros armazenados no Distribuidor.
EnumLogReaderAgents - retorna um objeto DataSet que contém informações sobre todos os Log Reader Agents no Distribuidor.
EnumMergeAgents - retorna um objeto DataSet que contém informações sobre todos os Merge Agents no Distribuidor.
EnumMiscellaneousAgents - retorna um objeto DataSet que contém informações sobre todos os outros agentes de replicação no Distribuidor.
EnumPublishers - retorna um objeto DataSet que contém informações sobre todos os Publicador nesse Distribuidor.
EnumPublishers2 - retorna um objeto DataSet que retorna os Publicadores que usam esse Distribuidor.
EnumQueueReaderAgents - retorna um objeto DataSet que contém informações sobre todos os Queue Reader Agents no Distribuidor.
EnumQueueReaderAgentSessionDetails - retorna um objeto DataSet que contém detalhes sobre o Queue Reader Agent e a sessão especificados.
EnumQueueReaderAgentSessions - retorna um objeto DataSet que contém informações de sessão sobre o Queue Reader Agent especificado.
EnumSnapshotAgents - retorna um objeto DataSet que contém informações sobre todos os Snapshot Agents no Distribuidor.
Para monitorar as propriedades de publicação para um Publicador específico no Distribuidor
Crie uma conexão com o Distribuidor usando a classe ServerConnection .
Consiga um objeto PublisherMonitor em um desses modos.
Criar uma instância da classe PublisherMonitor. Defina a propriedade Name para o Publicador e defina a propriedade ConnectionContext como ServerConnection criada na etapa 1. Chame o método LoadProperties para obter as propriedades do objeto. Se esse método retornar
false
, o nome do Publicador estava definido incorretamente ou a publicação não existe.Do PublisherMonitorCollection acessado por meio da propriedade PublisherMonitors de um objeto existente ReplicationMonitor .
Execute um ou mais dos métodos a seguir para retornar informações de replicação para todas as publicações que pertençam a esse Publicador.
EnumDistributionAgentSessionDetails - retorna um objeto DataSet que contém detalhes sobre o Distribution Agent e a sessão especificados.
EnumDistributionAgentSessions - retorna um objeto DataSet que contém informação da sessão sobre o Distribution Agent especificado.
EnumErrorRecords - retorna um objeto DataSet que contém informações de registro de erros sobre o erro especificado.
EnumLogReaderAgentSessionDetails - retorna um objeto DataSet que contém detalhes sobre o Log Reader Agent e a sessão especificados.
EnumLogReaderAgentSessions - retorna um objeto DataSet que contém informações de sessão sobre o Log Reader Agent especificado.
EnumMergeAgentSessionDetails - retorna um objeto DataSet que contém detalhes sobre o Merge Agent e a sessão especificados.
EnumMergeAgentSessionDetails2 - retorna um objeto DataSet que contém detalhes adicionais sobre o Merge Agent e a sessão especificados.
EnumMergeAgentSessions - retorna um objeto DataSet que contém informação da sessão para o Merge Agent especificado.
EnumMergeAgentSessions2 - retorna um objeto DataSet que contém informações de sessão adicional para o Merge Agent especificado.
EnumPublications - retorna um objeto DataSet que contém informações sobre todas as publicações nesse Distribuidor.
EnumPublications2 - retorna um objeto DataSet que contém informações adicionais sobre todas as publicações nesse Distribuidor.
EnumSnapshotAgentSessionDetails - retorna um objeto DataSet que contém detalhes sobre o Snapshot Agent e a sessão especificados.
EnumSnapshotAgentSessions - retorna um objeto DataSet que contém informação da sessão para o Snapshot Agent especificado.
EnumSubscriptions - retorna um objeto DataSet que contém informações sobre todas as assinaturas para publicações nesse Distribuidor.
Para monitorar as propriedades para uma publicação específica no Distribuidor
Crie uma conexão com o Distribuidor usando a classe ServerConnection .
Consiga um objeto PublicationMonitor em um desses modos.
Criar uma instância da classe PublicationMonitor. Defina as propriedades DistributionDBName, PublisherName, PublicationDBName, e Name para a publicação e defina a propriedade ConnectionContext como ServerConnection criado na etapa 1. Chame o método LoadProperties para obter as propriedades do objeto. Se esse método retornar
false
, as propriedades de publicação foram definidas incorretamente ou a publicação não existe.Do PublicationMonitorCollection acessado por meio da propriedade PublicationMonitors de um objeto existente PublisherMonitor .
Execute um ou mais dos métodos seguintes para retornar informações sobre essa publicação.
EnumErrorRecords - retorna um objeto DataSet que contém registros de erro sobre o erro especificado.
EnumLogReaderAgent - retorna um objeto DataSet que contém informações sobre o Log Reader Agent para essa publicação.
EnumMonitorThresholds - retorna um objeto DataSet que contém informações sobre o conjunto de limites de monitoração de avisos para essa publicação.
EnumQueueReaderAgent - retorna um objeto DataSet que contém informações sobre o Queue Reader Agent usado por essa publicação.
EnumSnapshotAgent - retorna um objeto DataSet que contém informações sobre o Snapshot Agent para essa publicação.
EnumSubscriptions - retorna um objeto DataSet que contém informações sobre assinaturas para essa publicação.
EnumSubscriptions2 - retorna um objeto DataSet que contém informações adicionais sobre assinaturas para essa publicação com base no SubscriptionResultOptionfornecido.
EnumTracerTokenHistory - retorna um objeto DataSet que contém informações de latência para o token de rastreamento especificado.
EnumTracerTokens - retorna um objeto DataSet que contém informações sobre todos os tokens de rastreamento inseridos nessa publicação.
Para monitorar os comandos transacionais que estão esperando para serem aplicados no Assinante.
Crie uma conexão com o Distribuidor usando a classe ServerConnection .
Consiga um objeto PublicationMonitor em um desses modos.
Criar uma instância da classe PublicationMonitor. Defina as propriedades DistributionDBName, PublisherName, PublicationDBName, e Name para a publicação e defina a propriedade ConnectionContext como ServerConnection criado na etapa 1. Chame o método LoadProperties para obter as propriedades do objeto. Se esse método retornar
false
, as propriedades de publicação foram definidas incorretamente ou a publicação não existe.Do PublicationMonitorCollection acessado por meio da propriedade PublicationMonitors de um objeto existente PublisherMonitor .
Execute o método TransPendingCommandInfo que retorna um objeto PendingCommandInfo .
Use as propriedades desse objeto PendingCommandInfo para determinar o número estimado de comandos pendentes e o tempo que levará para completar a entrega desses comandos.
Para definir os limites de aviso de monitoração para uma publicação
Crie uma conexão com o Distribuidor usando a classe ServerConnection .
Consiga um objeto PublicationMonitor em um desses modos.
Criar uma instância da classe PublicationMonitor. Defina as propriedades DistributionDBName, PublisherName, PublicationDBName, e Name para a publicação e defina a propriedade ConnectionContext como ServerConnection criado na etapa 1. Chame o método LoadProperties para obter as propriedades do objeto. Se esse método retornar
false
, as propriedades de publicação foram definidas incorretamente ou a publicação não existe.Do PublicationMonitorCollection acessado por meio da propriedade PublicationMonitors de um objeto existente PublisherMonitor .
Execute o método EnumMonitorThresholds . Observe as configurações de limite atuais no ArrayList retornado de objetos MonitorThreshold .
Execute o método ChangeMonitorThreshold . Passe os seguintes parâmetros:
metricID - um valor Int32 que representa a métrica de limite de monitoração da tabela a seguir:
Valor Descrição 1 expiration
- monitora a expiração iminente de assinaturas para publicações transacionais.2 latency
- monitora o desempenho de assinaturas para publicações transacionais.4 mergeexpiration
- monitora a expiração iminente de assinaturas para publicações de mesclagem.5 mergeslowrunduration
- monitora a duração de sincronizações de mesclagem em conexões da baixa largura da banda (discadas).6 mergefastrunduration
- monitora a duração de sincronizações de mesclagem em conexões da alta largura da banda (LAN).7 mergefastrunspeed
- monitora a taxa de sincronizações de mesclagem em conexões de alta largura da banda (LAN).8 mergeslowrunspeed
- monitora a taxa de sincronizações de mesclagem em conexões de baixa largura da banda (discadas).enable - Boolean valor que indica se a métrico está habilitado para a publicação.
thresholdValue - valor inteiro que define o limite.
shouldAlert - inteiro que indica se esse limite deve gerar um alerta.