Introdução às consultas contínuas
Neste documento, descreveremos as consultas contínuas do BigQuery.
As consultas contínuas do BigQuery são instruções SQL executadas continuamente. As consultas contínuas permitem analisar dados recebidos no BigQuery em tempo real. É possível inserir as linhas de saída produzidas por uma consulta contínua em uma tabela do BigQuery ou exportá-las para o Pub/Sub, o Bigtable ou o Spanner. As consultas contínuas podem processar dados que foram gravados em tabelas padrão do BigQuery usando um dos seguintes métodos:
- A API BigQuery Storage Write
- O método
tabledata.insertAll - Carregamento em lote
- A instrução DML
INSERT - Como modificar instruções da linguagem de manipulação de dados (DML)
como
DELETE,UPDATEeMERGEao exportar dados para o Pub/Sub. - Gravações dos resultados de uma consulta em lote em uma tabela permanente
- Gravações dos resultados de uma consulta contínua do BigQuery em uma tabela permanente
- Uma assinatura do Pub/Sub BigQuery
- Gravações do Dataflow para o BigQuery
- Gravações do Datastream para o BigQuery usando o modo de gravação somente anexar
Você pode usar consultas contínuas para realizar tarefas urgentes, como criar insights e agir imediatamente com base neles, aplicar a inferência de machine learning (ML) em tempo real e replicar dados em outras plataformas. Dessa forma, você pode usar o BigQuery como um dispositivo de tratamento de dados orientado a eventos para a lógica de decisão do aplicativo.
O diagrama a seguir mostra fluxos de trabalho comuns de consulta contínua:
Casos de uso
Veja alguns casos de uso comuns em que convém usar consultas contínuas:
- Serviços personalizados de interação com o cliente: use a IA generativa para criar mensagens personalizadas para cada interação com o cliente.
- Detecção de anomalias: crie soluções que permitam realizar detecção de anomalias e ameaças em dados complexos em tempo real, para que você possa reagir a problemas mais rapidamente.
- Pipelines personalizáveis baseados em eventos: use a integração de consulta contínua com o Pub/Sub para acionar aplicativos downstream com base nos dados recebidos.
- Aprimoramento de dados e extração de entidades: use consultas contínuas para realizar aprimoramento e transformação de dados em tempo real usando funções SQL e modelos de ML.
- ETL (extrair, transformar e carregar) reverso: execute ETL reverso em tempo real em outros sistemas de armazenamento mais adequados para veiculação de aplicativos de baixa latência. Por exemplo: analisar ou aprimorar dados de eventos gravados no BigQuery; e, em seguida, fazer streaming para o Bigtable ou o Spanner para veiculação do aplicativo.
Funcionalidade compatível
As seguintes operações são aceitas em consultas contínuas:
- Execução de
instruções
INSERTpara gravar dados a partir de uma consulta contínua em uma tabela do BigQuery. Execução de instruções
EXPORT DATApara publicar a saída de consultas contínuas em tópicos do Pub/Sub. Para mais informações, consulte Exportar dados para o Pub/Sub.A partir de um tópico do Pub/Sub, é possível usar os dados com outros serviços, como análise de streaming usando o Dataflow, ou usando os dados em um fluxo de trabalho de integração de aplicativos.
Execução de instruções
EXPORT DATApara exportar dados do BigQuery para tabelas Bigtable. Para mais informações, consulte Exportar dados para o Bigtable.Execução de instruções
EXPORT DATApara exportar dados do BigQuery para tabelas do Spanner. Para mais informações, consulte Exportar dados para o Spanner (ETL reverso).Chamando as seguintes funções de IA generativa:
AI.GENERATE-
- Essa função exige que você tenha um modelo remoto do BigQuery ML em um modelo da Vertex AI.
Chamar as seguintes funções de IA:
Essas funções exigem que você tenha um modelo remoto de ML do BigQuery em uma API Cloud AI.
Normalizar dados numéricos usando a função
ML.NORMALIZER.Usar funções do GoogleSQL sem estado, por exemplo, funções de conversão. Em funções sem estado, cada linha é processada independentemente de outras linhas na tabela.
Usar operações com estado, por exemplo,
JOINs, agregações e agregações de janela. Em operações com estado, o estado dos dados ingeridos é mantido em várias linhas ou intervalos de tempo para calcular um resultado preciso.Usar a função
APPENDSdo histórico de alterações para processar dados anexados de um momento específico.Usar a função
CHANGESdo histórico de alterações para processar dados alterados, incluindo anexos e mutações, de um momento específico ao exportar dados para o Pub/Sub. No entanto,CHANGESnão é compatível com o uso de uma operação com estado.
Operações com estado compatíveis
Para pedir suporte ou enviar feedback sobre esse recurso, envie um e-mail para bq-continuous-queries-feedback@google.com.
As operações com estado permitem que consultas contínuas realizem análises complexas que exigem a retenção de informações em várias linhas ou intervalos de tempo. Enquanto
funções sem estado processam cada linha de forma independente, operações com estado mantêm
o estado dos dados ingeridos para oferecer suporte a funções como JOINs, agregações e
agregações de janelas. Com esse recurso, é possível correlacionar eventos de diferentes fluxos ou calcular métricas ao longo do tempo, como uma média de 30 minutos, armazenando os dados necessários na memória enquanto a consulta é executada.
As consultas contínuas aceitam as seguintes operações com estado:
Autorização
Os Google Cloud tokens de acesso usados ao executar jobs de consulta contínua têm um time to live (TTL) de dois dias quando são gerados por uma conta de usuário. Portanto, esses jobs param de ser executados após dois dias. Os tokens de acesso gerados pelas contas de serviço podem ser executados por mais tempo, mas ainda precisam obedecer ao tempo máximo de execução da consulta. Para mais informações, consulte Executar uma consulta contínua usando uma conta de serviço.
Locais
Para conferir uma lista de regiões compatíveis, consulte Locais de consultas contínuas do BigQuery.
Limitações
As consultas contínuas estão sujeitas às seguintes limitações:
- O estado dos dados ingeridos é mantido apenas para as operações com estado específicas no pré-lançamento.
Embora as consultas contínuas agora sejam compatíveis com alguns tipos de
JOINs, agregações e agregações de janela, elas são restritas a operações com estado específicas. Nem todos os tipos de operações com estado são compatíveis. Não é possível usar os seguintes recursos de SQL em uma consulta contínua, a menos que eles estejam listados como uma operação com estado compatível:
Os seguintes operadores de consulta:
Operadores de conjunto de consulta
funções do BigQuery ML que não sejam as listadas em Funcionalidade compatível
Instruções de linguagem de definição de dados (DDL, na sigla em inglês)
Instruções de linguagem de manipulação de dados (DML, na sigla em inglês) exceto
INSERT.Instruções de linguagem de controle de dados (DCL, na sigla em inglês)
instruções
EXPORT DATAque não segmentam o Bigtable, o Pub/Sub ou o Spanner.
As consultas contínuas não aceitam as seguintes fontes de dados:
- Tabelas externas.
- Visualizações do esquema de informações.
- Tabelas do BigLake para Apache Iceberg no BigQuery.
- Tabelas curinga.
- Dados de upsert de captura de dados alterados (CDC).
- Visualizações materializadas.
- Visualizações definidas por outras limitações de consulta contínua, como operações
JOIN, funções agregadas, funções definidas pelo usuário ou tabelas com captura de dados de mudança ativada.
As consultas contínuas não são compatíveis com os recursos de segurança column- e da linha.
A saída de uma consulta contínua está sujeita às cotas e limites inerentes do serviço de destino para onde ela está sendo exportada.
Ao exportar dados para o Bigtable, o Spanner ou endpoints regionais do Pub/Sub, só é possível segmentar recursos do Bigtable, do Spanner ou do Pub/Sub que se enquadram no mesmo limite regional Google Cloud que o conjunto de dados do BigQuery que contém a tabela que você está consultando. Essa restrição não se aplica à exportação de dados para endpoints globais do Pub/Sub. Para mais informações sobre a exportação para uma política de roteamento de perfil de app do Bigtable, consulte Considerações sobre local.
Não é possível executar uma consulta contínua em uma tela de dados.
Não é possível modificar o SQL usado em uma consulta contínua enquanto o job da consulta contínua está em execução. Para mais informações, consulte Modificar o SQL de uma consulta contínua.
Se um job de consulta contínua ficar atrasado no processamento de dados recebidos e tiver um atraso de marca d'água de saída de mais de 48 horas, ele vai falhar. É possível executar a consulta novamente e usar a função
APPENDSouCHANGESdo histórico de alterações para retomar o processamento a partir do momento em que você interrompeu o job de consulta contínua anterior. Para mais informações, consulte Iniciar uma consulta contínua de um momento específico.Uma consulta contínua configurada com uma conta de usuário pode ser executada por até dois dias. Uma consulta contínua configurada com uma conta de serviço pode ser executada por até 150 dias. Quando o tempo máximo de execução da consulta é atingido, ela falha e para de processar os dados recebidos.
Embora as consultas contínuas sejam criadas usando recursos de confiabilidade do BigQuery, podem ocorrer problemas temporários ocasionais. Os problemas podem levar a uma certa quantidade de reprocessamento automático da sua consulta contínua, o que pode resultar em dados duplicados na saída da consulta contínua. Projete seus sistemas downstream para lidar com esses cenários.
Limitações de reserva
- Você precisa criar reservas da edição Enterprise ou da edição Enterprise Plus para executar consultas contínuas. As consultas contínuas não aceitam o modelo de faturamento de computação on demand.
- Quando você cria uma
CONTINUOUSatribuição de reserva, a reserva associada é limitada a no máximo 500 slots. Para solicitar um aumento desse limite, entre em contato com bq-continuous-queries-feedback@google.com. - Não é possível criar uma atribuição de reserva que usa um tipo de trabalho diferente na mesma reserva como uma atribuição de reserva de consulta contínua.
- Não é possível configurar a simultaneidade de consultas contínuas. O BigQuery
determina automaticamente o número de consultas contínuas que podem ser executadas
simultaneamente, com base nas atribuições de reserva disponíveis que usam o tipo de job
CONTINUOUS. - Ao executar várias consultas contínuas usando a mesma reserva, jobs individuais podem não dividir os recursos disponíveis de maneira justa, já que são definidos pela imparcialidade do BigQuery.
Escalonamento automático de slots
As consultas contínuas podem usar o escalonamento automático de slots para dimensionar dinamicamente a capacidade alocada e acomodar sua carga de trabalho. À medida que a carga de trabalho das consultas contínuas aumenta ou diminui, o BigQuery ajusta dinamicamente os slots.
Depois que uma consulta contínua começa a ser executada, ela detecta ativamente os dados recebidos, o que consome recursos de slot. Embora uma reserva com uma consulta contínua em execução não reduzir escala vertical para zero slots, uma consulta contínua inativa que está principalmente aguardando dados recebidos deve consumir uma quantidade mínima de slots, geralmente cerca de um.
Compartilhamento de slots inativos
As consultas contínuas podem usar o compartilhamento de slots ociosos para compartilhar recursos de slots não utilizados com outras reservas e tipos de jobs.
- Uma atribuição de reserva de
CONTINUOUSainda é necessária para executar uma consulta contínua e não pode depender apenas de slots inativos de outras reservas. Assim, uma atribuição de reserva doCONTINUOUSexige um valor de referência de slot diferente de zero ou uma configuração de escalonamento automático de slot diferente de zero. - Somente slots de valor de referência ociosos ou slots confirmados de uma atribuição de reserva
CONTINUOUSpodem ser compartilhados. Os slots com escalonamento automático não podem ser compartilhados como slots ociosos para outras reservas.
Preços
As consultas contínuas usam
Preços de computação de capacidade do BigQuery,
que são medidos em slots.
Para executar consultas contínuas, é preciso ter uma
reserva que use a
edição Enterprise ou Enterprise Plus
e uma atribuição de reserva
que usa o tipo de job CONTINUOUS.
O uso de outros recursos do BigQuery, como ingestão de dados e armazenamento, é cobrado conforme as taxas mostradas nos Preços do BigQuery.
O uso de outros serviços que recebem resultados de consulta contínua ou que são chamados durante o processamento de consultas é cobrado de acordo com as taxas publicadas para esses serviços. Para os preços de outros serviços do Google Cloud usados pelas consultas contínuas, consulte os seguintes tópicos:
A seguir
Tente criar uma consulta contínua.