Visão geral das ferramentas de introspecção

As ferramentas de introspecção do Spanner permitem investigar problemas no banco de dados. Elas consistem em um conjunto de tabelas integradas que podem ser consultadas para receber mais insights sobre consultas, transações, leituras e muito mais. Não sabe qual ferramenta usar para um problema específico? Veja na lista a seguir um resumo de cada ferramenta e os tipos de pergunta que elas podem ajudar a responder.

Estatísticas de consulta

Ao investigar problemas no banco de dados, é útil saber quais consultas são caras, executar com frequência ou verificar muitos dados.

As estatísticas de consulta são estatísticas agregadas de consultas, incluindo instruções DML e consultas de fluxo de alterações, reunidas em intervalos de 1, 10 e 60 minutos. As estatísticas são coletadas para instruções concluídas com sucesso, bem como aquelas que falharam, expiraram ou foram canceladas pelo usuário.

As estatísticas incluem o maior uso de CPU, contagem total de execuções de consulta, latência média, a maioria dos dados verificados e estatísticas básicas adicionais de consulta. Use essas estatísticas para ajudar a identificar consultas caras, frequentemente executadas ou com muitos dados.

É possível visualizar essas métricas em uma série temporal usando painéis de Insights de consulta. Esses painéis pré-criados ajudam você a visualizar picos de utilização da CPU e identificar consultas ineficientes.

Consultas ativas mais antigas

Às vezes, você quer analisar a carga de trabalho atual no sistema examinando as consultas em execução. Use a ferramenta Consultas ativas mais antigas para investigar consultas de longa duração que podem ter impacto sobre o desempenho do banco de dados. Essa ferramenta informa quais são as consultas, quando elas começaram a ser executadas e a qual sessão elas pertencem.

As consultas de fluxo de alterações não estão incluídas nas consultas ativas mais antigas.

Ler estatísticas

As estatísticas de leitura podem ser usadas para investigar as leituras mais comuns e que consomem recursos no banco de dados usando a API Reads do Spanner. Essas estatísticas são coletadas e armazenadas em 3 intervalos de tempo diferentes - minuto, 10 minutos e uma hora. Para cada intervalo de tempo, o Spanner rastreia as leituras que estão usando a maioria dos recursos.

Use as estatísticas de leitura para descobrir o uso combinado de recursos por todas as leituras, encontrar a maioria das leituras de CPU e descobrir como a frequência de uma leitura específica muda ao longo do tempo.

Estatísticas de transação

As estatísticas de transação podem ser usadas para investigar problemas relacionados à transação. Por exemplo, verifique transações de execução lenta que podem estar causando contenção ou identificar mudanças nas formas de transação que estão levando a regressões de desempenho. Cada linha contém estatísticas de todas as transações executadas no banco de dados durante intervalos de 1, 10 e 60 minutos.

É possível visualizar essas métricas em uma série temporal usando o painel Insights de transações. O painel pré-criado ajuda você a visualizar as latências das transações e a identificar transações problemáticas.

Estatísticas de bloqueio

As estatísticas de bloqueio podem ser usadas para investigar conflitos de bloqueio no seu banco de dados. Usadas com estatísticas de transações, é possível encontrar transações que causam conflitos de bloqueio ao adquirir bloqueios nas mesmas células ao mesmo tempo.

É possível visualizar essas métricas em uma série temporal usando o painel Bloquear insights. O painel pré-criado ajuda você a visualizar o tempo de espera de bloqueio e confirmar se as latências são causadas por contenções de bloqueio com tempo de espera alto.

Métodos de API incluídos em cada ferramenta

No Spanner, há uma sobreposição entre transações, leituras e consultas. Portanto, pode não ficar claro quais métodos de API são incluídos ao compilar os resultados de cada ferramenta de introspecção. A tabela a seguir lista os principais métodos de API e a relação deles com cada ferramenta.

Métodos de API Modos de transação Estatísticas de consulta Consultas ativas mais antigas Como gerenciar réplicas de leitura Estatísticas de transação Estatísticas de bloqueio
Ler em StreamingRead Transação somente de leitura1 No No Sim No No
Transação de leitura/gravação No No Sim Sim Sim
ExecuteSql, ExecuteStreamingSql Transação somente de leitura1 Sim2 Sim2 No No No
Transação de leitura/gravação Sim Sim No Sim Sim
ExecuteBatchDml Transações de leitura e gravação Sim3 Sim4 No Sim Sim
Commit Transações de leitura/gravação (DML5, Mutações6) No No No Sim Sim

Observações:

1 As transações somente leitura não estão incluídas nas estatísticas de transações ou de bloqueio. Somente transações de leitura e gravação estão incluídas nas estatísticas de transações e estatísticas de bloqueio.

2 As consultas executadas com a API PartitionQuery não são incluídas nas estatísticas da consulta ou nas consultas ativas mais antigas.

3 Um lote de instruções DML aparece nas estatísticas da consulta como uma única entrada.

4 As instruções do lote serão exibidas nas consultas ativas mais antigas, não no lote inteiro.

5 Operações DML não confirmadas não estão incluídas nas estatísticas da transação.

6 Mutações vazias que são efetivamente autônomas não são incluídas nas estatísticas de transação.

Estatísticas de tamanhos de tabela

Use as estatísticas de tamanhos de tabela para monitorar os tamanhos históricos das tabelas e índices no banco de dados.

Use estatísticas de tamanho de tabela para encontrar tendências nos tamanhos de tabelas, índices e tabelas de fluxo de alterações. Você também pode acompanhar seus maiores índices e tabelas.

Observe que esse recurso oferece apenas uma perspectiva histórica. Ele não é destinado ao monitoramento em tempo real.

Estatísticas de operações de tabela

Você pode usar as estatísticas de operações de tabela para fazer o seguinte:

  • Monitore o uso de tabelas e índices no banco de dados.
  • Encontre tendências no uso de tabelas e índices.
  • Identificar mudanças no tráfego.

Além disso, você pode correlacionar as alterações no armazenamento de tabelas com as alterações no tráfego de gravação.