Esta tradução de máquina é fornecida para sua comodidade.

Caso haja alguma divergência entre a versão em inglês e a traduzida, a versão em inglês prevalece. Acesse esta página para mais informações.

Criar um problema

Chamada REST de API para alertas de infraestrutura

Use a API REST de infraestrutura para adicionar, atualizar, excluir e listar condições de alerta. Você também pode gerenciar condições de alerta individuais usando a interface de monitoramento de infraestrutura.

Chamadas de API REST para alertas de infraestrutura não estão disponíveis no API Explorer.

Por que usar a API

Exemplos

Consistência

  • Defina o mesmo conjunto de condições para cada cluster sem ter que configurar sempre condições idênticas na interface de infraestrutura.
  • Gerencie múltiplas condições rapidamente, sem precisar atualizá-las uma por uma usando a interface.

Flexibilidade

  • Crie condições para um grupo arbitrário de hosts.
  • Desative ou exclua condições para hosts colocados offline a qualquer momento.
  • Crie uma condição com filtragem excludente (para instância, environment NOT LIKE x). Para saber mais sobre isso, consulte esta postagem sobre filtragem de exclusão.
  • Para AWS integração na nuvem, selecione atributos que ainda não foram enviados pela AWS .
  • Crie condição composta do alerta usando o where_clause, que permite especificar os limites de uma métrica secundária ou terciária.
  • Exceder a limitação de 500 facetas na condição do alerta NRQL .

Confiabilidade

  • Auditar quando uma condição foi atualizada pela última vez.

Requisitos

Para usar a API REST de infraestrutura, você precisa de:

Dica

Se a sua organização aloja dados no data center da UE, certifique-se de que está a utilizar o ponto final da região da UE.

Usando infraestrutura chamada de API

Aqui estão alguns comandos básicos cURL e suas respostas para infraestrutura condição do alerta. Dependendo do tipo de condição, as informações DATA fornecidas na chamada variarão para chamadas POST (adicionar) e PUT (atualizar).

As definições de cada atributo usado nos blocos data podem ser encontradas na seção Definições .

Condições de infraestrutura GET

Você pode GET uma lista de condições de infraestrutura ou GET uma condição de infraestrutura específica. Aqui estão algumas dicas para listar as condições de infraestrutura.

  • Para paginação, use os parâmetros limit (registros por página) e offset (quantos registros pular). O padrão é 50 registros por página e offset começa em 0 (não ignora nenhum registro).
  • Para definir o escopo dos resultados para uma política específica, use policy_id.

Dica

Se você quiser usar a resposta GET como modelo para sua entrada PUT ou POST, certifique-se de remover as informações created_at_epoch_millis, updated_at_epoch_millis e id .

OBTENHA uma lista de condições de infraestrutura

bash
$
curl -v -X GET --header "Api-Key:$API_KEY" "https://infra-api.newrelic.com/v2/alerts/conditions?policy_id=111111"

Para obter uma lista das 10 condições de infraestrutura além do limite de 50:

bash
$
curl -v -X GET --header "Api-Key:$API_KEY" "https://infra-api.newrelic.com/v2/alerts/conditions?policy_id=111111&offset=50&limit=10"

OBTENHA uma condição específica de infraestrutura

Para obter informações sobre uma única condição de infraestrutura:

bash
$
curl -v -X GET --header "Api-Key:$API_KEY" "https://infra-api.newrelic.com/v2/alerts/conditions/condition-id"

Criar (POST) uma condição de infraestrutura

Importante

Não inclua um "id": ao adicionar uma nova condição (POST). Ele será gerado quando a condição for criada.

Para adicionar uma condição de infraestrutura, use este comando básico cURL:

bash
$
curl -X POST 'https://infra-api.newrelic.com/v2/alerts/conditions' \
>
-H "Api-Key:$API_KEY" -i -H 'Content-Type: application/json' \
>
-d '{"data":{DATA object details}}'

Inclua detalhes no objeto DATA (seção -d ) para o tipo de condição de infraestrutura que você está adicionando:

Atualizar (PUT) uma condição de infraestrutura

Você só precisa incluir os campos que precisam ser alterados ao atualizar uma condição de infraestrutura. A API mantém os valores existentes para quaisquer campos ausentes.

Importante

Se você quiser alterar a condição type, não use PUT. Em vez disso, exclua a condição existente e adicione (POST) uma nova condição com os novos campos de condição type e all .

Para atualizar uma condição de infraestrutura, utilize este comando básico cURL. Para indicar qual condição deve ser atualizada, inclua o "id": .

Inclua detalhes no objeto DATA (seção -d ) para o tipo de condição de infraestrutura que você está atualizando:

Remover (DELETE) uma condição de infraestrutura

Para excluir uma condição de infraestrutura, use este comando básico cURL:

bash
$
curl -v -X DELETE --header "Api-Key:$API_KEY" "https://infra-api.newrelic.com/v2/alerts/conditions/condition_id"

Tipos de condições

Definições

Ao formatar seu comando cURL, use esses valores conforme necessário. Eles estão listados em ordem alfabética, não na ordem em que aparecem na sua chamada de API.

Field

Definition

comparison (enum)

Condition type: infra_metric, infra_process_running

O valor usado para definir o limite; por exemplo, "["above", "below", "equal"].

critical_threshold e warning_threshold

Condition type: todos

Este objeto identifica o valor limite antes de abrir um incidente.

  • O critical_threshold é obrigatório.

  • O warning_threshold é opcional e só pode ser usado com infra_metric condições.

    As chaves deste objeto dependem do tipo de condição.

    Condition type: infra_metric formato:

    "critical_threshold":{
    "value":<number>,
    "duration_minutes":<integer>,
    "time_function":"any" or "all"
    },

    Condition type: infra_process_running formato:

    "critical_threshold":{
    "value":<integer>,
    "duration_minutes":<integer>,
    },

    Condition type: infra_host_not_reporting formato:

    "critical_threshold":{
    "duration_minutes":<integer>,
    },

enabled (boleano)

Condition type: todos

Se a condição está ativada ou desativada; true ou false.

event_type (corda)

Condition type: infra_metric

O evento métrico; por exemplo, métrica de sistema, métrica de processo, métrica de armazenamento ou métrica de rede. Isto é preenchido automaticamente para integração de infraestrutura; por exemplo, StorageSample ou SystemSample.

filter (corda)

Condition type: todos

Se a condição foi feita na interface, filter aparece em vez de where_clause; por exemplo:

{and: [{is: {ec2InstanceType: "m3.medium"}}]}

Recomendação: Use where_clause ao criar uma nova condição.

id (inteiro)

Condition type: todos

O ID da condição localizado no URL.

  • GET: Este valor aparece na resposta GET.
  • PUT: inclua esse valor na seção DATA .
  • POST: não inclua isso na seção DATA .
  • DELETE: inclua esse valor na chamada -X DELETE .

integration_provider (corda)

Condition type: infra_metric

Para alertas sobre integração, use integration_provider em vez de event_type. Para ver valores válidos: Na documentação New Relic para seus serviços na nuvem, verifique a seção Find and use data.

Exemplo: na documentação de integração de monitoramento AWS RDS , você pode ver que o tipo de evento DatastoreSample pode ser usado com um valor integration_provider de RdsDbInstance para instância de banco de dados ou RdsDbCluster para cluster de banco de dados Aurora.

name (corda)

Condition type: todos

O nome da condição de alerta da infraestrutura; por exemplo:

"[test] process running"

policy_id (inteiro)

Condition type: todos

O ID único do ID da conta da política de alertas associado à condição; por exemplo, 1234567890. Este não é o ID global da política.

process_where_clause (corda)

Condition type: infra_process_running

Quaisquer filtros aplicados aos processos, especificamente na condição de alerta do processo em execução. Este parâmetro é obrigatório para esses tipos de condição do alerta. Por exemplo:

"commandName = '\''java'\''"

runbook_url (corda)

Condition type: all

A URL runbook a ser exibida na notificação.

select_value (corda)

Condition type: infra_metric

O nome do atributo para identificar a métrica sendo destino; por exemplo, "cpuPercent", "diskFreePercent", "memoryResidentSizeBytes", or "memoryFreeBytes/memoryTotalBytes*100". Isto é preenchido automaticamente para integração de infraestrutura; por exemplo, diskFreePercent.

type (enum)

Condition type: todos

O tipo de infraestrutura condição do alerta: "infra_process_running", "infra_metric" ou "infra_host_not_reporting".

violation_close_timer (inteiro)

Condition type: todos

A configuração do limite de tempo do incidente , expressa em horas. Os valores possíveis são 0, 1, 2, 4, 8,12, 24, 48, 72. Isso determina quanto tempo passará antes que um incidente seja fechado automaticamente.

Para novas condições, se um valor não for fornecido, os seguintes valores padrão serão usados:

  • Todas as condições: 24 hours

    Ao atualizar as condições existentes, se um valor for fornecido, ele substitui o valor existente, mas não afeta o incidente já aberto.

where_clause (corda)

Condition type: todos

Se aplicável, identifica quaisquer filtros de host de infraestrutura usados; por exemplo:

"(`hostname` LIKE '\''%cassandra%'\'')",