Este documento descreve como configurar uma verificação de tempo de atividade para validar o
código de resposta HTTP e os dados de resposta enviados por um recurso verificado. Por
padrão, as verificações de tempo de atividade HTTP verificam se o código de resposta é 2xx
. Além disso,
por padrão, os dados de resposta não são validados. No entanto, é possível modificar essas
configurações. Por exemplo, é possível configurar uma verificação de tempo de atividade HTTP para aceitar
códigos de resposta 2xx
e 3xx
. Para todas as verificações de tempo de atividade,
é possível especificar um valor que os dados de resposta
precisam ou não conter para que a verificação de tempo de atividade seja bem-sucedida.
Como validar os dados de resposta
É possível configurar o Cloud Monitoring para validar os dados de resposta de um recurso verificado ao criar ou editar uma verificação de tempo de atividade.
Console do Google Cloud
Para criar uma verificação de tempo de atividade que valide os dados de resposta, faça o seguinte:
-
No console do Google Cloud, acesse a página
Verificações de tempo de atividade:
Acesse Verificações de tempo de atividade
Se você usar a barra de pesquisa para encontrar essa página, selecione o resultado com o subtítulo Monitoramento.
- Clique em Criar verificação de tempo de atividade.
- Digite um Título e clique em Próxima.
- Insira o Alvo e clique em Próxima.
Configure a Validação de resposta:
- Para validar os dados da resposta, verifique se a opção A correspondência de conteúdo está ativada está visível e preencha os campos relacionados à validação de resposta. Para informações sobre essas opções, consulte a próxima seção deste documento.
- Para as verificações de tempo de atividade HTTP, configure os códigos de resposta aceitáveis.
Por padrão, as verificações de tempo de atividade HTTP marcam qualquer
resposta
2xx
como uma resposta bem-sucedida.
Clique em Próxima e conclua a configuração da verificação de tempo de atividade.
API Cloud Monitoring
Para configurar uma verificação de tempo de atividade para validar os dados de resposta,
preencha a matriz contentMatchers
do objeto
UptimeCheckConfig
.
Os objetos ContentMatcher
contêm os seguintes campos:
matcher
: descreve como a comparação é realizada. Para conferir uma lista de valores, consulteContentMatcherOption
.Não use o valor
CONTENT_MATCHER_OPTION_UNSPECIFIED
.content
: armazena o valor a ser pesquisado nos dados de resposta. O valor é um literal de string ou uma expressão regular.jsonPathMatcher
: armazena um objetoJsonPathMatcher
que descreve qual JSONpath pesquisar e como realizar a comparação.Omita esse campo, a menos que a verificação de tempo de atividade esteja validando um JSONpath específico.
O restante deste documento descreve como usar as opções de correspondência de conteúdo.
Opções para validar os dados de resposta
Esta seção descreve as estratégias de correspondência de string que podem ser usadas para validar a resposta enviada por um recurso verificado. Para cada estratégia, especifique um valor e se a verificação de tempo de atividade é bem-sucedida ou falha ao encontrar esse valor nos dados de resposta.
A resposta completa de um recurso verificado pode não ser pesquisada:
- Verificações de tempo de atividade HTTP e HTTPS: os primeiros 4 MB são pesquisados.
- Verificações de tempo de atividade do TCP: o primeiro MB é pesquisado.
Pesquisar uma substring literal
Console do Google Cloud
Para configurar a verificação de tempo de atividade para ser bem-sucedida quando os dados de resposta contiverem uma substring literal, use as seguintes configurações:
- Selecione Contains no menu Tipo de correspondência de conteúdo de resposta.
- Insira a substring literal no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
Para configurar a verificação de tempo de atividade para falhar quando os dados de resposta contêm uma substring literal, use as seguintes configurações:
- Selecione Não contém no menu Tipo de correspondência de conteúdo de resposta.
- Insira a substring literal no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
API Cloud Monitoring
Para configurar a verificação de tempo de atividade para ser bem-sucedida quando os dados de resposta contiverem uma substring literal, use os seguintes valores:
... "contentMatchers": [ { "content": "Set to the string to be matched.", "matcher": "CONTAINS_STRING" } ], ...
Para configurar a verificação de tempo de atividade para falhar quando os dados de resposta contiverem uma substring literal, use os seguintes valores:
... "contentMatchers": [ { "content": "Set to the string to be matched.", "matcher": "NOT_CONTAINS_STRING" } ], ...
A tabela a seguir mostra o status da verificação de disponibilidade para diferentes dados de resposta, strings de teste e tipos de teste:
Status da verificação de tempo de atividade | |||
---|---|---|---|
Dados de resposta | String de teste | Contém | Não contém |
abcd |
abcd |
pass | errada |
abc |
abcd |
errada | pass |
abc |
a |
pass | errada |
Uptime Checks |
Uptime |
pass | errada |
Uptime Checks |
uptime |
errada | pass |
Na tabela anterior, a coluna Dados de resposta descreve os dados retornados pelo recurso verificado, enquanto a coluna String de teste lista o literal da string. As duas colunas seguintes especificam o tipo de teste e o resultado da verificação de tempo de atividade.
Pesquisar usando uma expressão regular
Console do Google Cloud
Para configurar a verificação de tempo de atividade para que ela seja bem-sucedida quando os dados de resposta corresponderem a uma expressão regular, use as seguintes configurações:
- Selecione Corresponde ao regex no menu Tipo de correspondência de conteúdo de resposta.
- Insira uma expressão regular no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
Para configurar a verificação de tempo de atividade para falhar quando os dados de resposta corresponderem a uma expressão regular, use as seguintes configurações:
- Selecione Não corresponde ao regex no menu Tipo de correspondência de conteúdo de resposta.
- Insira uma expressão regular no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
API Cloud Monitoring
Para configurar a verificação de tempo de atividade para ser bem-sucedida quando os dados de resposta corresponderem a uma expressão regular, use os seguintes valores:
... "contentMatchers": [ { "content": "Set to the regular expression to be matched.", "matcher": "MATCHES_REGEX" } ], ...
Para configurar a verificação de tempo de atividade a falhar quando os dados de resposta corresponderem a uma expressão regular, use os seguintes valores:
... "contentMatchers": [ { "content": "Set to the regular expression to be matched.", "matcher": "NOT_MATCHES_REGEX" } ], ...
A tabela a seguir mostra o status da verificação de tempo de atividade para diferentes dados de resposta, expressões regulares e tipos de teste:
Status da verificação de tempo de atividade | |||
---|---|---|---|
Dados de resposta | Regex | Corresponde à regex | Não corresponde à regex |
abcd |
abcd |
pass | errada |
Uptime Checks |
[uU]ptime |
pass | errada |
Uptime Checks |
[a-z]{6} |
errada | pass |
Uptime Checks |
[a-zA-Z]{6} |
pass | errada |
Na tabela anterior, a coluna Dados de resposta descreve os dados retornados pelo recurso verificado, enquanto a coluna Regex lista a expressão regular. As duas colunas seguintes especificam o tipo de teste e o resultado da verificação de tempo de atividade.
Pesquisar um campo específico em uma resposta JSON
É possível configurar uma verificação de tempo de atividade para validar um JSONPath. Quando você seleciona um teste JSONPath, ele compara um valor de caminho com um número, uma string literal ou uma expressão regular:
Ao especificar um JSONPath, você precisa especificar o objeto raiz com $.
e, em seguida, seguir com um identificador de campo específico. Quando a resposta JSON
contiver uma matriz de elementos, use colchetes, []
, para identificar o
elemento de matriz específico a ser correspondido. Os exemplos a seguir ilustram a
sintaxe do caminho:
$.type
corresponde ao campotype
de um objeto raiz.$.[0].address.city
corresponde ao campocity
no objetoaddress
armazenado no primeiro elemento de matriz da resposta JSON.$.content[0].phone
corresponde ao campophone
do primeiro elemento da matriz do campocontent
. O campocontent
é filho do objeto raiz.
É possível configurar um teste de tempo de atividade para corresponder a vários campos. Considere o seguinte JSON:
[
{
...
"address": {
...
"city": "Gwenborough",
"geo": {
"lat": "-37.3159",
"lng": "81.1496"
}
},
},
...
]
Para corresponder ao caminho inteiro do campo geo
no primeiro elemento da matriz,
defina o JSONPath como $.[0].address.geo
e insira o valor completo
no campo de conteúdo:
{
"lat": "-37.3159",
"lng": "81.1496"
}
Se você quiser experimentar essas opções, encontre um site público que retorne uma resposta JSON. Por exemplo, consulte Teste JSON.
Comparar JSONpath com um número ou literal de string
Console do Google Cloud
Para configurar a verificação de tempo de atividade para ser aprovada quando um JSONpath específico nos dados de resposta corresponder a uma string literal, use as seguintes configurações:
- Selecione Corresponde a JSONPath no menu Tipo de correspondência de conteúdo de resposta.
- Insira o caminho no campo JSONPath.
- Insira o número ou a string literal no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
Para configurar a verificação de tempo de atividade para falhar quando um JSONpath específico nos dados de resposta corresponder a uma string literal, use as seguintes configurações:
- Selecione Não corresponde a JSONPath no menu Tipo de correspondência de conteúdo de resposta.
- Insira o caminho no campo JSONPath.
- Insira o número ou a string literal no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
API Cloud Monitoring
Para configurar a verificação de tempo de atividade para que ela seja bem-sucedida quando um campo específico na resposta formatada em JSON corresponder a um número ou uma string literal, use os seguintes valores para o objeto ContentMatcher
:
... "contentMatchers": [ { "content" : "Set to a number, a boolean, or the string to be matched.", "matcher" : "MATCHES_JSON_PATH", "jsonPathMatcher" : { "jsonPath" : "Set to the JSONpath.", "jsonMatcher" : "EXACT_MATCH" } ], ...
Para configurar a verificação de tempo de atividade para falhar quando um campo específico na resposta formatada em JSON corresponder a um número ou uma string literal, use os seguintes valores para o objeto ContentMatcher
:
... "contentMatchers": [ { "content" : "Set to a number, a boolean, or the string to be matched.", "matcher" : "NOT_MATCHES_JSON_PATH", "jsonPathMatcher" : { "jsonPath" : "Set to the JSONpath.", "jsonMatcher" : "EXACT_MATCH" } ], ...
Para ilustrar como os testes de correspondência de string do JSONpath funcionam, considere os seguintes dados de resposta JSON:
{ "name": "Sample Uptime Check", "type": "JSONpath", "content": [ { "id": 1, "phone": "1234567890", "alias": "Exact", "enabled": true, }, { "id": 2, "phone": "1234512345", "alias": "Regex", "enabled": false, } ] }
A tabela a seguir mostra o status da verificação de disponibilidade da resposta anterior, mas para diferentes caminhos, valores e tipos de teste:
Status da verificação de tempo de atividade | |||
---|---|---|---|
JSONpath | Valor de teste | Correspondências de JSONPath | O JSONPath não corresponde |
$. |
"JSONpath" |
pass | errada |
$. |
"Sample" |
errada | pass |
$. |
"Sample Uptime Check" |
pass | errada |
$. |
1 |
pass | errada |
$. |
"Exact" |
pass | errada |
$. |
true |
pass | errada |
Na tabela anterior, a coluna JSONpath identifica qual elemento testar, e a coluna Valor do teste lista o valor. As duas colunas seguintes especificam o tipo de teste e o resultado da verificação de tempo de atividade.
Comparar JSONPath com uma expressão regular
A correspondência de expressões regulares oferece suporte à correspondência de uma string, um número, um booleano e valores JSON nulos.
Console do Google Cloud
Para configurar a verificação de tempo de atividade para ser bem-sucedida quando um JSONpath específico nos dados de resposta corresponder a uma expressão regular, use as seguintes configurações:
- Selecione Corresponde a JSONPath no menu Tipo de correspondência de conteúdo de resposta.
- Insira o caminho no campo JSONPath.
- Insira a expressão regular no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
Para configurar a verificação de tempo de atividade para falhar quando um JSONpath específico nos dados de resposta corresponder a uma expressão regular, use as seguintes configurações:
- Selecione Não corresponde a JSONPath no menu Tipo de correspondência de conteúdo de resposta.
- Insira o caminho no campo JSONPath.
- Insira a expressão regular no campo Conteúdo da resposta.
- Para verificar a configuração, clique em Testar.
API Cloud Monitoring
Para configurar a verificação de tempo de atividade para ser bem-sucedida quando um campo específico na resposta formatada em JSON corresponder a uma expressão regular, use os seguintes valores para o objeto ContentMatcher
:
... "contentMatchers": [ { "content" : "Set to the regular expression to be matched." "matcher" : "MATCHES_JSON_PATH", "jsonPathMatcher" : { "jsonPath" : "Set to the JSONpath.", "jsonMatcher" : "REGEX_MATCH" } ], ...
Para configurar a verificação de tempo de atividade a falhar quando um campo específico na resposta formatada em JSON corresponder a uma expressão regular, use os seguintes valores para o objeto ContentMatcher
:
... "contentMatchers": [ { "content" : "Set to the regular expression to be matched.", "matcher" : "NOT_MATCHES_JSON_PATH", "jsonPathMatcher" : { "jsonPath" : "Set to the JSONpath.", "jsonMatcher" : "REGEX_MATCH" } ], ...
Para ilustrar como os testes de expressão regular do JSONpath funcionam, considere os seguintes dados de resposta JSON:
{ "name": "Sample Uptime Check", "type": "JSONpath", "content": [ { "id": 1, "phone": "1234567890", "alias": "Exact", "enabled": true, }, { "id": 2, "phone": "1234512345", "alias": "Regex", "enabled": false, } ] }
A tabela a seguir mostra o status da verificação de tempo de atividade da resposta anterior, mas para diferentes caminhos, expressões regulares e tipos de teste:
Status da verificação de tempo de atividade | |||
---|---|---|---|
JSONpath | Regex | O JSONpath corresponde à regex | O JSONpath não corresponde à regex |
$. |
[A-Z]{4}Path |
pass | errada |
$. |
Sample |
errada | pass |
$. |
. |
pass | errada |
$. |
2 |
pass | errada |
$. |
"[12345]{2}" |
pass | errada |
$. |
f. |
pass | errada |
Na tabela anterior, a coluna JSONpath identifica qual elemento testar e a coluna Regex lista a expressão regular. As duas colunas seguintes especificam o tipo de teste e o resultado da verificação de tempo de atividade.
A seguir
- Criar uma verificação de tempo de atividade
- Gerenciar verificações de tempo de atividade
- Criar políticas de alertas para verificações de tempo de atividade