Events reference
An event is a generic container used by Sensu to provide context to checks and metrics. The context, called observation data or event data, contains information about the originating entity and the corresponding check or metric result. An event must contain a status or metrics. In certain cases, an event can contain both a status and metrics. These generic containers allow Sensu to handle different types of events in the observability pipeline. Because events are polymorphic in nature, it is important to never assume their contents (or lack of content).
Event format
Sensu events contain:
entity
scope (required)- Information about the source of the event, including any attributes defined in the entity specification
check
scope (optional if themetrics
scope is present)- Information about how the event was created, including any attributes defined in the check specification
- Information about the event and its history, including any check attributes defined in the event specification on this page
metrics
scope (optional if thecheck
scope is present)- Metric points in Sensu metric format
timestamp
- Time that the event occurred in seconds since the Unix epoch
id
- Universally unique identifier (UUID) for the event (logged as
event_id
)
- Universally unique identifier (UUID) for the event (logged as
Example status-only event
The following example shows the complete resource definition for a status-only event:
---
type: Event
api_version: core/v2
metadata:
namespace: default
spec:
check:
check_hooks: null
command: check-cpu-usage -w 75 -c 90
duration: 5.058211427
env_vars: null
executed: 1617050501
handlers: []
high_flap_threshold: 0
history:
- executed: 1617050261
status: 0
- executed: 1617050321
status: 0
- executed: 1617050381
status: 0
- executed: 1617050441
status: 0
- executed: 1617050501
status: 0
interval: 60
is_silenced: false
processed_by: sensu-centos
issued: 1617050501
last_ok: 1617050501
low_flap_threshold: 0
metadata:
name: check_cpu
namespace: default
occurrences: 5
occurrences_watermark: 5
output: |
CheckCPU TOTAL OK: total=0.41 user=0.2 nice=0.0 system=0.2 idle=99.59 iowait=0.0 irq=0.0 softirq=0.0 steal=0.0 guest=0.0 guest_nice=0.0
output_metric_format: ""
output_metric_handlers: null
proxy_entity_name: ""
publish: true
round_robin: false
runtime_assets:
- check-cpu-usage
scheduler: memory
secrets: null
state: passing
status: 0
stdin: false
subdue: null
subscriptions:
- system
timeout: 0
total_state_change: 0
ttl: 0
entity:
deregister: false
deregistration: {}
entity_class: agent
last_seen: 1617050501
metadata:
name: sensu-centos
namespace: default
redact:
- password
- passwd
- pass
- api_key
- api_token
- access_key
- secret_key
- private_key
- secret
sensu_agent_version: 6.2.6
subscriptions:
- linux
- entity:sensu-centos
system:
arch: amd64
cloud_provider: ""
hostname: sensu-centos
libc_type: glibc
network:
interfaces:
- addresses:
- 127.0.0.1/8
- ::1/128
name: lo
- addresses:
- 10.0.2.15/24
- fe80::a268:dcce:3be:1c73/64
mac: 08:00:27:8b:c9:3f
name: eth0
- addresses:
- 172.28.128.45/24
- fe80::a00:27ff:feb2:dc46/64
mac: 08:00:27:b2:dc:46
name: eth1
os: linux
platform: centos
platform_family: rhel
platform_version: 7.5.1804
processes: null
vm_role: guest
vm_system: vbox
user: agent
pipelines:
- api_version: core/v2
type: Pipeline
name: incident_alerts
id: 3c3e68f6-6db7-40d3-9b84-4d61817ae559
sequence: 5
timestamp: 1617050507
{
"type": "Event",
"api_version": "core/v2",
"metadata": {
"namespace": "default"
},
"spec": {
"check": {
"check_hooks": null,
"command": "check-cpu-usage -w 75 -c 90",
"duration": 5.058211427,
"env_vars": null,
"executed": 1617050501,
"handlers": [],
"high_flap_threshold": 0,
"history": [
{
"executed": 1617050261,
"status": 0
},
{
"executed": 1617050321,
"status": 0
},
{
"executed": 1617050381,
"status": 0
},
{
"executed": 1617050441,
"status": 0
},
{
"executed": 1617050501,
"status": 0
}
],
"interval": 60,
"is_silenced": false,
"processed_by": "sensu-centos",
"issued": 1617050501,
"last_ok": 1617050501,
"low_flap_threshold": 0,
"metadata": {
"name": "check_cpu",
"namespace": "default"
},
"occurrences": 5,
"occurrences_watermark": 5,
"output": "CheckCPU TOTAL OK: total=0.41 user=0.2 nice=0.0 system=0.2 idle=99.59 iowait=0.0 irq=0.0 softirq=0.0 steal=0.0 guest=0.0 guest_nice=0.0\n",
"output_metric_format": "",
"output_metric_handlers": null,
"proxy_entity_name": "",
"publish": true,
"round_robin": false,
"runtime_assets": [
"check-cpu-usage"
],
"scheduler": "memory",
"secrets": null,
"state": "passing",
"status": 0,
"stdin": false,
"subdue": null,
"subscriptions": [
"system"
],
"timeout": 0,
"total_state_change": 0,
"ttl": 0
},
"entity": {
"deregister": false,
"deregistration": {},
"entity_class": "agent",
"last_seen": 1617050501,
"metadata": {
"name": "sensu-centos",
"namespace": "default"
},
"redact": [
"password",
"passwd",
"pass",
"api_key",
"api_token",
"access_key",
"secret_key",
"private_key",
"secret"
],
"sensu_agent_version": "6.2.6",
"subscriptions": [
"linux",
"entity:sensu-centos"
],
"system": {
"arch": "amd64",
"cloud_provider": "",
"hostname": "sensu-centos",
"libc_type": "glibc",
"network": {
"interfaces": [
{
"addresses": [
"127.0.0.1/8",
":1/128"
],
"name": "lo"
},
{
"addresses": [
"10.0.2.15/24",
"fe80::a268:dcce:3be:1c73/64"
],
"mac": "08:00:27:8b:c9:3f",
"name": "eth0"
},
{
"addresses": [
"172.28.128.45/24",
"fe80::a00:27ff:feb2:dc46/64"
],
"mac": "08:00:27:b2:dc:46",
"name": "eth1"
}
]
},
"os": "linux",
"platform": "centos",
"platform_family": "rhel",
"platform_version": "7.5.1804",
"processes": null,
"vm_role": "guest",
"vm_system": "vbox"
},
"user": "agent"
},
"pipelines": [
{
"api_version": "core/v2",
"type": "Pipeline",
"name": "incident_alerts"
}
],
"id": "3c3e68f6-6db7-40d3-9b84-4d61817ae559",
"sequence": 5,
"timestamp": 1617050507
}
}
Example status-only event from the Sensu API
Sensu sends events to the backend in json
format, without the outer-level spec
wrapper or type
and api_version
attributes that are included in the wrapped-json
format.
This is the format that events are in when Sensu sends them to the observability pipeline for processing:
{
"check": {
"command": "check-cpu-usage -w 75 -c 90",
"handlers": [],
"high_flap_threshold": 0,
"interval": 60,
"low_flap_threshold": 0,
"publish": true,
"runtime_assets": [
"check-cpu-usage"
],
"subscriptions": [
"system"
],
"proxy_entity_name": "",
"check_hooks": null,
"stdin": false,
"subdue": null,
"ttl": 0,
"timeout": 0,
"round_robin": false,
"duration": 5.058211427,
"executed": 1617050501,
"history": [
{
"status": 0,
"executed": 1617050261
},
{
"status": 0,
"executed": 1617050321
},
{
"status": 0,
"executed": 1617050381
},
{
"status": 0,
"executed": 1617050441
},
{
"status": 0,
"executed": 1617050501
}
],
"issued": 1617050501,
"output": "CheckCPU TOTAL OK: total=0.4 user=0.2 nice=0.0 system=0.2 idle=99.6 iowait=0.0 irq=0.0 softirq=0.0 steal=0.0 guest=0.0 guest_nice=0.0\n",
"state": "passing",
"status": 0,
"total_state_change": 0,
"last_ok": 1617050501,
"occurrences": 5,
"occurrences_watermark": 5,
"output_metric_format": "",
"output_metric_handlers": null,
"env_vars": null,
"metadata": {
"name": "check_cpu",
"namespace": "default"
},
"secrets": null,
"is_silenced": false,
"processed_by": "sensu-centos",
"scheduler": "memory"
},
"entity": {
"entity_class": "agent",
"system": {
"hostname": "sensu-centos",
"os": "linux",
"platform": "centos",
"platform_family": "rhel",
"platform_version": "7.5.1804",
"network": {
"interfaces": [
{
"name": "lo",
"addresses": [
"127.0.0.1/8",
"::1/128"
]
},
{
"name": "eth0",
"mac": "08:00:27:8b:c9:3f",
"addresses": [
"10.0.2.15/24",
"fe80::a268:dcce:3be:1c73/64"
]
},
{
"name": "eth1",
"mac": "08:00:27:b2:dc:46",
"addresses": [
"172.28.128.45/24",
"fe80::a00:27ff:feb2:dc46/64"
]
}
]
},
"arch": "amd64",
"libc_type": "glibc",
"vm_system": "vbox",
"vm_role": "guest",
"cloud_provider": "",
"processes": null
},
"subscriptions": [
"linux",
"entity:sensu-centos"
],
"last_seen": 1617049781,
"deregister": false,
"deregistration": {},
"user": "agent",
"redact": [
"password",
"passwd",
"pass",
"api_key",
"api_token",
"access_key",
"secret_key",
"private_key",
"secret"
],
"metadata": {
"name": "sensu-centos",
"namespace": "default"
},
"sensu_agent_version": "6.2.6"
},
"pipelines": [
{
"api_version": "core/v2",
"type": "Pipeline",
"name": "incident_alerts"
}
],
"id": "3c3e68f6-6db7-40d3-9b84-4d61817ae559",
"metadata": {
"namespace": "default"
},
"sequence": 5,
"timestamp": 1617050507
}
Example metrics-only event
This example shows a complete metrics-only event, retrieved with sensuctl event info:
---
type: Event
api_version: core/v2
metadata:
namespace: default
spec:
check:
check_hooks: null
command: system-check
duration: 3.012411959
env_vars: null
executed: 1635959903
handlers: []
high_flap_threshold: 0
history:
- executed: 1635959873
status: 0
- executed: 1635959883
status: 0
- executed: 1635959893
status: 0
- executed: 1635959903
status: 0
interval: 10
is_silenced: false
issued: 1635959903
last_ok: 1635959903
low_flap_threshold: 0
metadata:
labels:
sensu.io/managed_by: sensuctl
name: system-check
namespace: default
occurrences: 4
occurrences_watermark: 4
output: |+
# HELP system_cpu_cores [GAUGE] Number of cpu cores on the system
# TYPE system_cpu_cores GAUGE
system_cpu_cores{} 1 1635959903645
# HELP system_cpu_idle [GAUGE] Percent of time all cpus were idle
# TYPE system_cpu_idle GAUGE
system_cpu_idle{cpu="cpu0"} 98.94366197187135 1635959903645
system_cpu_idle{cpu="cpu-total"} 98.94366197187135 1635959903645
# HELP system_cpu_used [GAUGE] Percent of time all cpus were used
# TYPE system_cpu_used GAUGE
system_cpu_used{cpu="cpu0"} 1.0563380281286499 1635959903645
system_cpu_used{cpu="cpu-total"} 1.0563380281286499 1635959903645
# HELP system_cpu_user [GAUGE] Percent of time total cpu was used by normal processes in user mode
# TYPE system_cpu_user GAUGE
system_cpu_user{cpu="cpu0"} 0.7042253521124505 1635959903645
system_cpu_user{cpu="cpu-total"} 0.7042253521124505 1635959903645
# HELP system_cpu_system [GAUGE] Percent of time all cpus used by processes executed in kernel mode
# TYPE system_cpu_system GAUGE
system_cpu_system{cpu="cpu0"} 0.35211267605672564 1635959903645
system_cpu_system{cpu="cpu-total"} 0.35211267605672564 1635959903645
# HELP system_cpu_nice [GAUGE] Percent of time all cpus used by niced processes in user mode
# TYPE system_cpu_nice GAUGE
system_cpu_nice{cpu="cpu0"} 0 1635959903645
system_cpu_nice{cpu="cpu-total"} 0 1635959903645
# HELP system_cpu_iowait [GAUGE] Percent of time all cpus waiting for I/O to complete
# TYPE system_cpu_iowait GAUGE
system_cpu_iowait{cpu="cpu0"} 0 1635959903645
system_cpu_iowait{cpu="cpu-total"} 0 1635959903645
# HELP system_cpu_irq [GAUGE] Percent of time all cpus servicing interrupts
# TYPE system_cpu_irq GAUGE
system_cpu_irq{cpu="cpu0"} 0 1635959903645
system_cpu_irq{cpu="cpu-total"} 0 1635959903645
# HELP system_cpu_sortirq [GAUGE] Percent of time all cpus servicing software interrupts
# TYPE system_cpu_sortirq GAUGE
system_cpu_sortirq{cpu="cpu0"} 0 1635959903645
system_cpu_sortirq{cpu="cpu-total"} 0 1635959903645
# HELP system_cpu_stolen [GAUGE] Percent of time all cpus serviced virtual hosts operating systems
# TYPE system_cpu_stolen GAUGE
system_cpu_stolen{cpu="cpu0"} 0 1635959903645
system_cpu_stolen{cpu="cpu-total"} 0 1635959903645
# HELP system_cpu_guest [GAUGE] Percent of time all cpus serviced guest operating system
# TYPE system_cpu_guest GAUGE
system_cpu_guest{cpu="cpu0"} 0 1635959903645
system_cpu_guest{cpu="cpu-total"} 0 1635959903645
# HELP system_cpu_guest_nice [GAUGE] Percent of time all cpus serviced niced guest operating system
# TYPE system_cpu_guest_nice GAUGE
system_cpu_guest_nice{cpu="cpu0"} 0 1635959903645
system_cpu_guest_nice{cpu="cpu-total"} 0 1635959903645
# HELP system_mem_used [GAUGE] Percent of memory used
# TYPE system_mem_used GAUGE
system_mem_used{} 24.63435866529588 1635959903645
# HELP system_mem_used_bytes [GAUGE] Used memory in bytes
# TYPE system_mem_used_bytes GAUGE
system_mem_used_bytes{} 2.56159744e+08 1635959903645
# HELP system_mem_total_bytes [GAUGE] Total memory in bytes
# TYPE system_mem_total_bytes GAUGE
system_mem_total_bytes{} 1.039847424e+09 1635959903645
# HELP system_swap_used [GAUGE] Percent of swap used
# TYPE system_swap_used GAUGE
system_swap_used{} 0.0976564362648702 1635959903645
# HELP system_swap_used_bytes [GAUGE] Used swap in bytes
# TYPE system_swap_used_bytes GAUGE
system_swap_used_bytes{} 2.56159744e+08 1635959903645
# HELP system_swap_total_bytes [GAUGE] Total swap in bytes
# TYPE system_swap_total_bytes GAUGE
system_swap_total_bytes{} 2.147479552e+09 1635959903645
# HELP system_load_load1 [GAUGE] System load averaged over 1 minute, high load value dependant on number of cpus in system
# TYPE system_load_load1 GAUGE
system_load_load1{} 0.09 1635959903645
# HELP system_load_load5 [GAUGE] System load averaged over 5 minute, high load value dependent on number of cpus in system
# TYPE system_load_load5 GAUGE
system_load_load5{} 0.04 1635959903645
# HELP system_load_load15 [GAUGE] System load averaged over 15 minute, high load value dependent on number of cpus in system
# TYPE system_load_load15 GAUGE
system_load_load15{} 0.05 1635959903645
# HELP system_load_load1_per_cpu [GAUGE] System load averaged over 1 minute normalized by cpu count, values > 1 means system may be overloaded
# TYPE system_load_load1_per_cpu GAUGE
system_load_load1_per_cpu{} 0.09 1635959903645
# HELP system_load_load5_per_cpu [GAUGE] System load averaged over 5 minute normalized by cpu count, values > 1 means system may be overloaded
# TYPE system_load_load5_per_cpu GAUGE
system_load_load5_per_cpu{} 0.04 1635959903645
# HELP system_load_load15_per_cpu [GAUGE] System load averaged over 15 minute normalized by cpu count, values > 1 means system may be overloaded
# TYPE system_load_load15_per_cpu GAUGE
system_load_load15_per_cpu{} 0.05 1635959903645
# HELP system_host_uptime [COUNTER] Host uptime in seconds
# TYPE system_host_uptime COUNTER
system_host_uptime{} 15488 1635959903645
# HELP system_host_processes [GAUGE] Number of host processes
# TYPE system_host_processes GAUGE
system_host_processes{} 112 1635959903645
output_metric_format: prometheus_text
output_metric_handlers: null
pipelines: []
processed_by: sensu-centos
proxy_entity_name: ""
publish: true
round_robin: false
runtime_assets:
- system-check
scheduler: memory
secrets: null
state: passing
status: 0
stdin: false
subdue: null
subscriptions:
- system
timeout: 0
total_state_change: 0
ttl: 0
entity:
deregister: false
deregistration: {}
entity_class: agent
last_seen: 1635959903
metadata:
created_by: admin
name: sensu-centos
namespace: default
redact:
- password
- passwd
- pass
- api_key
- api_token
- access_key
- secret_key
- private_key
- secret
sensu_agent_version: 6.5.4
subscriptions:
- system
- entity:sensu-centos
- webserver
system:
arch: amd64
cloud_provider: ""
hostname: sensu-centos
libc_type: glibc
network:
interfaces:
- addresses:
- 127.0.0.1/8
- ::1/128
name: lo
- addresses:
- 10.0.2.15/24
- fe80::20b8:8cea:fa4:2e57/64
mac: 08:00:27:8b:c9:3f
name: eth0
- addresses:
- 192.168.200.95/24
- fe80::a00:27ff:fe40:ab31/64
mac: 08:00:27:40:ab:31
name: eth1
os: linux
platform: centos
platform_family: rhel
platform_version: 7.9.2009
processes: null
vm_role: guest
vm_system: vbox
user: agent
id: 07425e48-e163-47d3-8bc8-17fbaa27e469
pipelines: null
sequence: 122
timestamp: 1635959906
{
"type": "Event",
"api_version": "core/v2",
"metadata": {
"namespace": "default"
},
"spec": {
"check": {
"check_hooks": null,
"command": "system-check",
"duration": 3.012411959,
"env_vars": null,
"executed": 1635959903,
"handlers": [],
"high_flap_threshold": 0,
"history": [
{
"executed": 1635959873,
"status": 0
},
{
"executed": 1635959883,
"status": 0
},
{
"executed": 1635959893,
"status": 0
},
{
"executed": 1635959903,
"status": 0
}
],
"interval": 10,
"is_silenced": false,
"issued": 1635959903,
"last_ok": 1635959903,
"low_flap_threshold": 0,
"metadata": {
"labels": {
"sensu.io/managed_by": "sensuctl"
},
"name": "system-check",
"namespace": "default"
},
"occurrences": 4,
"occurrences_watermark": 4,
"output": "# HELP system_cpu_cores [GAUGE] Number of cpu cores on the system\n# TYPE system_cpu_cores GAUGE\nsystem_cpu_cores{} 1 1635959903645\n# HELP system_cpu_idle [GAUGE] Percent of time all cpus were idle\n# TYPE system_cpu_idle GAUGE\nsystem_cpu_idle{cpu=\"cpu0\"} 98.94366197187135 1635959903645\nsystem_cpu_idle{cpu=\"cpu-total\"} 98.94366197187135 1635959903645\n# HELP system_cpu_used [GAUGE] Percent of time all cpus were used\n# TYPE system_cpu_used GAUGE\nsystem_cpu_used{cpu=\"cpu0\"} 1.0563380281286499 1635959903645\nsystem_cpu_used{cpu=\"cpu-total\"} 1.0563380281286499 1635959903645\n# HELP system_cpu_user [GAUGE] Percent of time total cpu was used by normal processes in user mode\n# TYPE system_cpu_user GAUGE\nsystem_cpu_user{cpu=\"cpu0\"} 0.7042253521124505 1635959903645\nsystem_cpu_user{cpu=\"cpu-total\"} 0.7042253521124505 1635959903645\n# HELP system_cpu_system [GAUGE] Percent of time all cpus used by processes executed in kernel mode\n# TYPE system_cpu_system GAUGE\nsystem_cpu_system{cpu=\"cpu0\"} 0.35211267605672564 1635959903645\nsystem_cpu_system{cpu=\"cpu-total\"} 0.35211267605672564 1635959903645\n# HELP system_cpu_nice [GAUGE] Percent of time all cpus used by niced processes in user mode\n# TYPE system_cpu_nice GAUGE\nsystem_cpu_nice{cpu=\"cpu0\"} 0 1635959903645\nsystem_cpu_nice{cpu=\"cpu-total\"} 0 1635959903645\n# HELP system_cpu_iowait [GAUGE] Percent of time all cpus waiting for I/O to complete\n# TYPE system_cpu_iowait GAUGE\nsystem_cpu_iowait{cpu=\"cpu0\"} 0 1635959903645\nsystem_cpu_iowait{cpu=\"cpu-total\"} 0 1635959903645\n# HELP system_cpu_irq [GAUGE] Percent of time all cpus servicing interrupts\n# TYPE system_cpu_irq GAUGE\nsystem_cpu_irq{cpu=\"cpu0\"} 0 1635959903645\nsystem_cpu_irq{cpu=\"cpu-total\"} 0 1635959903645\n# HELP system_cpu_sortirq [GAUGE] Percent of time all cpus servicing software interrupts\n# TYPE system_cpu_sortirq GAUGE\nsystem_cpu_sortirq{cpu=\"cpu0\"} 0 1635959903645\nsystem_cpu_sortirq{cpu=\"cpu-total\"} 0 1635959903645\n# HELP system_cpu_stolen [GAUGE] Percent of time all cpus serviced virtual hosts operating systems\n# TYPE system_cpu_stolen GAUGE\nsystem_cpu_stolen{cpu=\"cpu0\"} 0 1635959903645\nsystem_cpu_stolen{cpu=\"cpu-total\"} 0 1635959903645\n# HELP system_cpu_guest [GAUGE] Percent of time all cpus serviced guest operating system\n# TYPE system_cpu_guest GAUGE\nsystem_cpu_guest{cpu=\"cpu0\"} 0 1635959903645\nsystem_cpu_guest{cpu=\"cpu-total\"} 0 1635959903645\n# HELP system_cpu_guest_nice [GAUGE] Percent of time all cpus serviced niced guest operating system\n# TYPE system_cpu_guest_nice GAUGE\nsystem_cpu_guest_nice{cpu=\"cpu0\"} 0 1635959903645\nsystem_cpu_guest_nice{cpu=\"cpu-total\"} 0 1635959903645\n# HELP system_mem_used [GAUGE] Percent of memory used\n# TYPE system_mem_used GAUGE\nsystem_mem_used{} 24.63435866529588 1635959903645\n# HELP system_mem_used_bytes [GAUGE] Used memory in bytes\n# TYPE system_mem_used_bytes GAUGE\nsystem_mem_used_bytes{} 2.56159744e+08 1635959903645\n# HELP system_mem_total_bytes [GAUGE] Total memory in bytes\n# TYPE system_mem_total_bytes GAUGE\nsystem_mem_total_bytes{} 1.039847424e+09 1635959903645\n# HELP system_swap_used [GAUGE] Percent of swap used\n# TYPE system_swap_used GAUGE\nsystem_swap_used{} 0.0976564362648702 1635959903645\n# HELP system_swap_used_bytes [GAUGE] Used swap in bytes\n# TYPE system_swap_used_bytes GAUGE\nsystem_swap_used_bytes{} 2.56159744e+08 1635959903645\n# HELP system_swap_total_bytes [GAUGE] Total swap in bytes\n# TYPE system_swap_total_bytes GAUGE\nsystem_swap_total_bytes{} 2.147479552e+09 1635959903645\n# HELP system_load_load1 [GAUGE] System load averaged over 1 minute, high load value dependant on number of cpus in system\n# TYPE system_load_load1 GAUGE\nsystem_load_load1{} 0.09 1635959903645\n# HELP system_load_load5 [GAUGE] System load averaged over 5 minute, high load value dependent on number of cpus in system\n# TYPE system_load_load5 GAUGE\nsystem_load_load5{} 0.04 1635959903645\n# HELP system_load_load15 [GAUGE] System load averaged over 15 minute, high load value dependent on number of cpus in system\n# TYPE system_load_load15 GAUGE\nsystem_load_load15{} 0.05 1635959903645\n# HELP system_load_load1_per_cpu [GAUGE] System load averaged over 1 minute normalized by cpu count, values > 1 means system may be overloaded\n# TYPE system_load_load1_per_cpu GAUGE\nsystem_load_load1_per_cpu{} 0.09 1635959903645\n# HELP system_load_load5_per_cpu [GAUGE] System load averaged over 5 minute normalized by cpu count, values > 1 means system may be overloaded\n# TYPE system_load_load5_per_cpu GAUGE\nsystem_load_load5_per_cpu{} 0.04 1635959903645\n# HELP system_load_load15_per_cpu [GAUGE] System load averaged over 15 minute normalized by cpu count, values > 1 means system may be overloaded\n# TYPE system_load_load15_per_cpu GAUGE\nsystem_load_load15_per_cpu{} 0.05 1635959903645\n# HELP system_host_uptime [COUNTER] Host uptime in seconds\n# TYPE system_host_uptime COUNTER\nsystem_host_uptime{} 15488 1635959903645\n# HELP system_host_processes [GAUGE] Number of host processes\n# TYPE system_host_processes GAUGE\nsystem_host_processes{} 112 1635959903645\n\n",
"output_metric_format": "prometheus_text",
"output_metric_handlers": null,
"pipelines": [],
"processed_by": "sensu-centos",
"proxy_entity_name": "",
"publish": true,
"round_robin": false,
"runtime_assets": [
"system-check"
],
"scheduler": "memory",
"secrets": null,
"state": "passing",
"status": 0,
"stdin": false,
"subdue": null,
"subscriptions": [
"system"
],
"timeout": 0,
"total_state_change": 0,
"ttl": 0
},
"entity": {
"deregister": false,
"deregistration": {},
"entity_class": "agent",
"last_seen": 1635959903,
"metadata": {
"created_by": "admin",
"name": "sensu-centos",
"namespace": "default"
},
"redact": [
"password",
"passwd",
"pass",
"api_key",
"api_token",
"access_key",
"secret_key",
"private_key",
"secret"
],
"sensu_agent_version": "6.5.4",
"subscriptions": [
"system",
"entity:sensu-centos",
"webserver"
],
"system": {
"arch": "amd64",
"cloud_provider": "",
"hostname": "sensu-centos",
"libc_type": "glibc",
"network": {
"interfaces": [
{
"addresses": [
"127.0.0.1/8",
":1/128"
],
"name": "lo"
},
{
"addresses": [
"10.0.2.15/24",
"fe80::20b8:8cea:fa4:2e57/64"
],
"mac": "08:00:27:8b:c9:3f",
"name": "eth0"
},
{
"addresses": [
"192.168.200.95/24",
"fe80::a00:27ff:fe40:ab31/64"
],
"mac": "08:00:27:40:ab:31",
"name": "eth1"
}
]
},
"os": "linux",
"platform": "centos",
"platform_family": "rhel",
"platform_version": "7.9.2009",
"processes": null,
"vm_role": "guest",
"vm_system": "vbox"
},
"user": "agent"
},
"id": "07425e48-e163-47d3-8bc8-17fbaa27e469",
"pipelines": null,
"sequence": 122,
"timestamp": 1635959906
}
}
Metrics data points are not included in events retrieved with sensuctl event info — those events include check output text rather than a set of metrics points. To view metrics points data as shown in the following example, create a pipeline workflow that includes a debug handler that prints events to a JSON file:
{
"metrics": {
"points": [
{
"name": "system_cpu_sortirq",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_sortirq",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_guest",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_guest",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_mem_used_bytes",
"value": 260579328,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_mem_total_bytes",
"value": 1039847424,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_swap_used",
"value": 0.0736237976528123,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_used",
"value": 0.6756756756291793,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_used",
"value": 0.6756756756291793,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_nice",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_nice",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_irq",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_irq",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_load_load1",
"value": 0.01,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_host_uptime",
"value": 10642,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "counter"
}
]
},
{
"name": "system_host_processes",
"value": 116,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_load_load5_per_cpu",
"value": 0.02,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_cores",
"value": 1,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_swap_used_bytes",
"value": 260579328,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_load_load5",
"value": 0.02,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_mem_used",
"value": 25.059381019344624,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_swap_total_bytes",
"value": 2147479552,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_load_load1_per_cpu",
"value": 0.01,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_load_load15_per_cpu",
"value": 0.05,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_idle",
"value": 99.32432432437082,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
},
{
"name": "cpu",
"value": "cpu0"
}
]
},
{
"name": "system_cpu_idle",
"value": 99.32432432437082,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_user",
"value": 0.3378378378376302,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_user",
"value": 0.3378378378376302,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_iowait",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_iowait",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_load_load15",
"value": 0.05,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_system",
"value": 0.3378378378376302,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
},
{
"name": "cpu",
"value": "cpu0"
}
]
},
{
"name": "system_cpu_system",
"value": 0.3378378378376302,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_stolen",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_stolen",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "prom_type",
"value": "gauge"
},
{
"name": "cpu",
"value": "cpu-total"
}
]
},
{
"name": "system_cpu_guest_nice",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu0"
},
{
"name": "prom_type",
"value": "gauge"
}
]
},
{
"name": "system_cpu_guest_nice",
"value": 0,
"timestamp": 1635952533,
"tags": [
{
"name": "cpu",
"value": "cpu-total"
},
{
"name": "prom_type",
"value": "gauge"
}
]
}
]
},
"metadata": {
"namespace": "default"
},
"id": "afdeb823-74c2-4921-891a-465a2095cb5a",
"sequence": 6,
"pipelines": [
{
"api_version": "core/v2",
"type": "Pipeline",
"name": "debug_pipeline"
}
],
"timestamp": 1635952536,
"entity": {
"entity_class": "agent",
"system": {
"hostname": "sensu-centos",
"os": "linux",
"platform": "centos",
"platform_family": "rhel",
"platform_version": "7.9.2009",
"network": {
"interfaces": [
{
"name": "lo",
"addresses": [
"127.0.0.1/8",
"::1/128"
]
},
{
"name": "eth0",
"mac": "08:00:27:8b:c9:3f",
"addresses": [
"10.0.2.15/24",
"fe80::20b8:8cea:fa4:2e57/64"
]
},
{
"name": "eth1",
"mac": "08:00:27:40:ab:31",
"addresses": [
"192.168.200.95/24",
"fe80::a00:27ff:fe40:ab31/64"
]
}
]
},
"arch": "amd64",
"libc_type": "glibc",
"vm_system": "vbox",
"vm_role": "guest",
"cloud_provider": "",
"processes": null
},
"subscriptions": [
"system",
"entity:sensu-centos"
],
"last_seen": 1635952533,
"deregister": false,
"deregistration": {},
"user": "agent",
"redact": [
"password",
"passwd",
"pass",
"api_key",
"api_token",
"access_key",
"secret_key",
"private_key",
"secret"
],
"metadata": {
"name": "sensu-centos",
"namespace": "default"
},
"sensu_agent_version": "6.5.4"
},
"check": {
"command": "system-check",
"handlers": [],
"high_flap_threshold": 0,
"interval": 10,
"low_flap_threshold": 0,
"publish": true,
"runtime_assets": [
"system-check"
],
"subscriptions": [
"system"
],
"proxy_entity_name": "",
"check_hooks": null,
"stdin": false,
"subdue": null,
"ttl": 0,
"timeout": 0,
"round_robin": false,
"duration": 3.01062768,
"executed": 1635952533,
"history": [
{
"status": 0,
"executed": 1635952283
},
{
"status": 0,
"executed": 1635952293
},
{
"status": 0,
"executed": 1635952303
},
{
"status": 0,
"executed": 1635952313
},
{
"status": 0,
"executed": 1635952421
},
{
"status": 0,
"executed": 1635952533
}
],
"issued": 1635952533,
"output": "# HELP system_cpu_cores [GAUGE] Number of cpu cores on the system\n# TYPE system_cpu_cores GAUGE\nsystem_cpu_cores{} 1 1635952533657\n# HELP system_cpu_idle [GAUGE] Percent of time all cpus were idle\n# TYPE system_cpu_idle GAUGE\nsystem_cpu_idle{cpu=\"cpu0\"} 99.32432432437082 1635952533657\nsystem_cpu_idle{cpu=\"cpu-total\"} 99.32432432437082 1635952533657\n# HELP system_cpu_used [GAUGE] Percent of time all cpus were used\n# TYPE system_cpu_used GAUGE\nsystem_cpu_used{cpu=\"cpu0\"} 0.6756756756291793 1635952533657\nsystem_cpu_used{cpu=\"cpu-total\"} 0.6756756756291793 1635952533657\n# HELP system_cpu_user [GAUGE] Percent of time total cpu was used by normal processes in user mode\n# TYPE system_cpu_user GAUGE\nsystem_cpu_user{cpu=\"cpu0\"} 0.3378378378376302 1635952533657\nsystem_cpu_user{cpu=\"cpu-total\"} 0.3378378378376302 1635952533657\n# HELP system_cpu_system [GAUGE] Percent of time all cpus used by processes executed in kernel mode\n# TYPE system_cpu_system GAUGE\nsystem_cpu_system{cpu=\"cpu0\"} 0.3378378378376302 1635952533657\nsystem_cpu_system{cpu=\"cpu-total\"} 0.3378378378376302 1635952533657\n# HELP system_cpu_nice [GAUGE] Percent of time all cpus used by niced processes in user mode\n# TYPE system_cpu_nice GAUGE\nsystem_cpu_nice{cpu=\"cpu0\"} 0 1635952533657\nsystem_cpu_nice{cpu=\"cpu-total\"} 0 1635952533657\n# HELP system_cpu_iowait [GAUGE] Percent of time all cpus waiting for I/O to complete\n# TYPE system_cpu_iowait GAUGE\nsystem_cpu_iowait{cpu=\"cpu0\"} 0 1635952533657\nsystem_cpu_iowait{cpu=\"cpu-total\"} 0 1635952533657\n# HELP system_cpu_irq [GAUGE] Percent of time all cpus servicing interrupts\n# TYPE system_cpu_irq GAUGE\nsystem_cpu_irq{cpu=\"cpu0\"} 0 1635952533657\nsystem_cpu_irq{cpu=\"cpu-total\"} 0 1635952533657\n# HELP system_cpu_sortirq [GAUGE] Percent of time all cpus servicing software interrupts\n# TYPE system_cpu_sortirq GAUGE\nsystem_cpu_sortirq{cpu=\"cpu0\"} 0 1635952533657\nsystem_cpu_sortirq{cpu=\"cpu-total\"} 0 1635952533657\n# HELP system_cpu_stolen [GAUGE] Percent of time all cpus serviced virtual hosts operating systems\n# TYPE system_cpu_stolen GAUGE\nsystem_cpu_stolen{cpu=\"cpu0\"} 0 1635952533657\nsystem_cpu_stolen{cpu=\"cpu-total\"} 0 1635952533657\n# HELP system_cpu_guest [GAUGE] Percent of time all cpus serviced guest operating system\n# TYPE system_cpu_guest GAUGE\nsystem_cpu_guest{cpu=\"cpu0\"} 0 1635952533657\nsystem_cpu_guest{cpu=\"cpu-total\"} 0 1635952533657\n# HELP system_cpu_guest_nice [GAUGE] Percent of time all cpus serviced niced guest operating system\n# TYPE system_cpu_guest_nice GAUGE\nsystem_cpu_guest_nice{cpu=\"cpu0\"} 0 1635952533657\nsystem_cpu_guest_nice{cpu=\"cpu-total\"} 0 1635952533657\n# HELP system_mem_used [GAUGE] Percent of memory used\n# TYPE system_mem_used GAUGE\nsystem_mem_used{} 25.059381019344624 1635952533657\n# HELP system_mem_used_bytes [GAUGE] Used memory in bytes\n# TYPE system_mem_used_bytes GAUGE\nsystem_mem_used_bytes{} 2.60579328e+08 1635952533657\n# HELP system_mem_total_bytes [GAUGE] Total memory in bytes\n# TYPE system_mem_total_bytes GAUGE\nsystem_mem_total_bytes{} 1.039847424e+09 1635952533657\n# HELP system_swap_used [GAUGE] Percent of swap used\n# TYPE system_swap_used GAUGE\nsystem_swap_used{} 0.0736237976528123 1635952533657\n# HELP system_swap_used_bytes [GAUGE] Used swap in bytes\n# TYPE system_swap_used_bytes GAUGE\nsystem_swap_used_bytes{} 2.60579328e+08 1635952533657\n# HELP system_swap_total_bytes [GAUGE] Total swap in bytes\n# TYPE system_swap_total_bytes GAUGE\nsystem_swap_total_bytes{} 2.147479552e+09 1635952533657\n# HELP system_load_load1 [GAUGE] System load averaged over 1 minute, high load value dependant on number of cpus in system\n# TYPE system_load_load1 GAUGE\nsystem_load_load1{} 0.01 1635952533657\n# HELP system_load_load5 [GAUGE] System load averaged over 5 minute, high load value dependent on number of cpus in system\n# TYPE system_load_load5 GAUGE\nsystem_load_load5{} 0.02 1635952533657\n# HELP system_load_load15 [GAUGE] System load averaged over 15 minute, high load value dependent on number of cpus in system\n# TYPE system_load_load15 GAUGE\nsystem_load_load15{} 0.05 1635952533657\n# HELP system_load_load1_per_cpu [GAUGE] System load averaged over 1 minute normalized by cpu count, values \\u003e 1 means system may be overloaded\n# TYPE system_load_load1_per_cpu GAUGE\nsystem_load_load1_per_cpu{} 0.01 1635952533657\n# HELP system_load_load5_per_cpu [GAUGE] System load averaged over 5 minute normalized by cpu count, values \\u003e 1 means system may be overloaded\n# TYPE system_load_load5_per_cpu GAUGE\nsystem_load_load5_per_cpu{} 0.02 1635952533657\n# HELP system_load_load15_per_cpu [GAUGE] System load averaged over 15 minute normalized by cpu count, values \\u003e 1 means system may be overloaded\n# TYPE system_load_load15_per_cpu GAUGE\nsystem_load_load15_per_cpu{} 0.05 1635952533657\n# HELP system_host_uptime [COUNTER] Host uptime in seconds\n# TYPE system_host_uptime COUNTER\nsystem_host_uptime{} 10642 1635952533657\n# HELP system_host_processes [GAUGE] Number of host processes\n# TYPE system_host_processes GAUGE\nsystem_host_processes{} 116 1635952533657\n\n",
"state": "passing",
"status": 0,
"total_state_change": 0,
"last_ok": 1635952533,
"occurrences": 6,
"occurrences_watermark": 6,
"output_metric_format": "prometheus_text",
"output_metric_handlers": null,
"env_vars": null,
"metadata": {
"name": "system-check",
"namespace": "default",
"labels": {
"sensu.io/managed_by": "sensuctl"
}
},
"secrets": null,
"is_silenced": false,
"scheduler": "memory",
"processed_by": "sensu-centos",
"pipelines": [],
"output_metric_thresholds": [
{
"name": "system_mem_used",
"tags": null,
"null_status": 1,
"thresholds": [
{
"min": "",
"max": "75.0",
"status": 1
},
{
"min": "",
"max": "90.0",
"status": 2
}
]
},
{
"name": "system_host_processes",
"tags": [
{
"name": "namespace",
"value": "production"
}
],
"null_status": 1,
"thresholds": [
{
"min": "5",
"max": "50",
"status": 1
},
{
"min": "2",
"max": "75",
"status": 2
}
]
}
]
}
}
Example status and metrics event
The following example resource definition for a status and metrics event contains both a check and metrics, retrieved with sensuctl event info:
---
type: Event
api_version: core/v2
metadata:
namespace: default
spec:
check:
check_hooks: null
command: http-check --url http://localhost && http-perf --url http://localhost
--warning 1s --critical 2s
duration: 0.022274319
env_vars: null
executed: 1635959379
handlers: null
high_flap_threshold: 0
history:
- executed: 1635952820
status: 0
- executed: 1635952835
status: 0
- executed: 1635952850
status: 0
- executed: 1635952865
status: 0
- executed: 1635952880
status: 0
interval: 5
is_silenced: false
issued: 1635952880
last_ok: 1635952880
low_flap_threshold: 0
metadata:
name: collect-metrics
namespace: default
occurrences: 5
occurrences_watermark: 5
output: |
http-check OK: HTTP Status 200 for http://localhost
http-perf OK: 0.001150s | dns_duration=0.000257, tls_handshake_duration=0.000000, connect_duration=0.000088, first_byte_duration=0.001131, total_request_duration=0.001150
output_metric_format: nagios_perfdata
output_metric_handlers: null
pipelines: []
processed_by: sensu-centos
proxy_entity_name: ""
publish: true
round_robin: false
runtime_assets:
- http-checks
scheduler: memory
secrets: null
state: passing
status: 0
stdin: false
subdue: null
subscriptions:
- webserver
timeout: 0
total_state_change: 0
ttl: 0
entity:
deregister: false
deregistration: {}
entity_class: agent
last_seen: 1635959379
metadata:
created_by: admin
name: sensu-centos
namespace: default
redact:
- password
- passwd
- pass
- api_key
- api_token
- access_key
- secret_key
- private_key
- secret
sensu_agent_version: 6.5.4
subscriptions:
- system
- entity:sensu-centos
- webserver
system:
arch: amd64
cloud_provider: ""
hostname: sensu-centos
libc_type: glibc
network:
interfaces:
- addresses:
- 127.0.0.1/8
- ::1/128
name: lo
- addresses:
- 10.0.2.15/24
- fe80::20b8:8cea:fa4:2e57/64
mac: 08:00:27:8b:c9:3f
name: eth0
- addresses:
- 192.168.200.95/24
- fe80::a00:27ff:fe40:ab31/64
mac: 08:00:27:40:ab:31
name: eth1
os: linux
platform: centos
platform_family: rhel
platform_version: 7.9.2009
processes: null
vm_role: guest
vm_system: vbox
user: agent
id: 12545deb-0e0f-480f-addf-34545d5a01c6
pipelines:
- type: Pipeline
api_version: core/v2
name: status_and_metrics_pipeline
sequence: 5
timestamp: 1635952880
{
"type": "Event",
"api_version": "core/v2",
"metadata": {
"namespace": "default"
},
"spec": {
"check": {
"check_hooks": null,
"command": "http-check --url http://localhost && http-perf --url http://localhost --warning 1s --critical 2s",
"duration": 0.022274319,
"env_vars": null,
"executed": 1635959379,
"handlers": null,
"high_flap_threshold": 0,
"history": [
{
"executed": 1635952820,
"status": 0
},
{
"executed": 1635952835,
"status": 0
},
{
"executed": 1635952850,
"status": 0
},
{
"executed": 1635952865,
"status": 0
},
{
"executed": 1635952880,
"status": 0
}
],
"interval": 5,
"is_silenced": false,
"issued": 1635952880,
"last_ok": 1635952880,
"low_flap_threshold": 0,
"metadata": {
"name": "collect-metrics",
"namespace": "default"
},
"occurrences": 5,
"occurrences_watermark": 5,
"output": "http-check OK: HTTP Status 200 for http://localhost\nhttp-perf OK: 0.001150s | dns_duration=0.000257, tls_handshake_duration=0.000000, connect_duration=0.000088, first_byte_duration=0.001131, total_request_duration=0.001150\n",
"output_metric_format": "nagios_perfdata",
"output_metric_handlers": null,
"pipelines": [],
"processed_by": "sensu-centos",
"proxy_entity_name": "",
"publish": true,
"round_robin": false,
"runtime_assets": [
"http-checks"
],
"scheduler": "memory",
"secrets": null,
"state": "passing",
"status": 0,
"stdin": false,
"subdue": null,
"subscriptions": [
"webserver"
],
"timeout": 0,
"total_state_change": 0,
"ttl": 0
},
"entity": {
"deregister": false,
"deregistration": {},
"entity_class": "agent",
"last_seen": 1635959379,
"metadata": {
"created_by": "admin",
"name": "sensu-centos",
"namespace": "default"
},
"redact": [
"password",
"passwd",
"pass",
"api_key",
"api_token",
"access_key",
"secret_key",
"private_key",
"secret"
],
"sensu_agent_version": "6.5.4",
"subscriptions": [
"system",
"entity:sensu-centos",
"webserver"
],
"system": {
"arch": "amd64",
"cloud_provider": "",
"hostname": "sensu-centos",
"libc_type": "glibc",
"network": {
"interfaces": [
{
"addresses": [
"127.0.0.1/8",
":1/128"
],
"name": "lo"
},
{
"addresses": [
"10.0.2.15/24",
"fe80::20b8:8cea:fa4:2e57/64"
],
"mac": "08:00:27:8b:c9:3f",
"name": "eth0"
},
{
"addresses": [
"192.168.200.95/24",
"fe80::a00:27ff:fe40:ab31/64"
],
"mac": "08:00:27:40:ab:31",
"name": "eth1"
}
]
},
"os": "linux",
"platform": "centos",
"platform_family": "rhel",
"platform_version": "7.9.2009",
"processes": null,
"vm_role": "guest",
"vm_system": "vbox"
},
"user": "agent"
},
"id": "12545deb-0e0f-480f-addf-34545d5a01c6",
"pipelines": [
{
"type": "Pipeline",
"api_version": "core/v2",
"name": "status_and_metrics_pipeline"
}
],
"sequence": 5,
"timestamp": 1635952880
}
}
Metrics data points are not included in events retrieved with sensuctl event info — those events include check output text rather than a set of metrics points. To view metrics points data as shown in the following example, create a pipeline workflow that includes a debug handler that prints events to a JSON file:
{
"entity": {
"entity_class": "agent",
"system": {
"hostname": "sensu-centos",
"os": "linux",
"platform": "centos",
"platform_family": "rhel",
"platform_version": "7.9.2009",
"network": {
"interfaces": [
{
"name": "lo",
"addresses": [
"127.0.0.1/8",
"::1/128"
]
},
{
"name": "eth0",
"mac": "08:00:27:8b:c9:3f",
"addresses": [
"10.0.2.15/24",
"fe80::20b8:8cea:fa4:2e57/64"
]
},
{
"name": "eth1",
"mac": "08:00:27:40:ab:31",
"addresses": [
"192.168.200.95/24",
"fe80::a00:27ff:fe40:ab31/64"
]
}
]
},
"arch": "amd64",
"libc_type": "glibc",
"vm_system": "vbox",
"vm_role": "guest",
"cloud_provider": "",
"processes": null
},
"subscriptions": [
"system",
"entity:sensu-centos",
"webserver"
],
"last_seen": 1635952880,
"deregister": false,
"deregistration": {},
"user": "agent",
"redact": [
"password",
"passwd",
"pass",
"api_key",
"api_token",
"access_key",
"secret_key",
"private_key",
"secret"
],
"metadata": {
"name": "sensu-centos",
"namespace": "default",
"created_by": "admin"
},
"sensu_agent_version": "6.5.4"
},
"check": {
"command": "http-check --url http://localhost \\u0026\\u0026 http-perf --url http://localhost --warning 1s --critical 2s",
"handlers": [],
"high_flap_threshold": 0,
"interval": 15,
"low_flap_threshold": 0,
"publish": true,
"runtime_assets": [
"http-checks"
],
"subscriptions": [
"webserver"
],
"proxy_entity_name": "",
"check_hooks": null,
"stdin": false,
"subdue": null,
"ttl": 0,
"timeout": 0,
"round_robin": false,
"duration": 0.018747388,
"executed": 1635952880,
"history": [
{
"status": 0,
"executed": 1635952820
},
{
"status": 0,
"executed": 1635952835
},
{
"status": 0,
"executed": 1635952850
},
{
"status": 0,
"executed": 1635952865
},
{
"status": 0,
"executed": 1635952880
}
],
"issued": 1635952880,
"output": "http-check OK: HTTP Status 200 for http://localhost\nhttp-perf OK: 0.001059s | dns_duration=0.000235, tls_handshake_duration=0.000000, connect_duration=0.000083, first_byte_duration=0.001040, total_request_duration=0.001059\n",
"state": "passing",
"status": 0,
"total_state_change": 0,
"last_ok": 1635952880,
"occurrences": 5,
"occurrences_watermark": 5,
"output_metric_format": "nagios_perfdata",
"output_metric_handlers": null,
"env_vars": null,
"metadata": {
"name": "collect-metrics",
"namespace": "default"
},
"secrets": null,
"is_silenced": false,
"scheduler": "memory",
"processed_by": "sensu-centos",
"pipelines": []
},
"metrics": {
"points": [
{
"name": "dns_duration",
"value": 0.000235,
"timestamp": 1635952880,
"tags": null
},
{
"name": "tls_handshake_duration",
"value": 0,
"timestamp": 1635952880,
"tags": null
},
{
"name": "connect_duration",
"value": 0.000083,
"timestamp": 1635952880,
"tags": null
},
{
"name": "first_byte_duration",
"value": 0.00104,
"timestamp": 1635952880,
"tags": null
},
{
"name": "total_request_duration",
"value": 0.001059,
"timestamp": 1635952880,
"tags": null
}
]
},
"metadata": {
"namespace": "default"
},
"id": "7cde3e3f-beee-408f-b89a-1edccd0d3edb",
"sequence": 5,
"pipelines": [
{
"type": "Pipeline",
"api_version": "core/v2",
"name": "debug_pipeline"
}
],
"timestamp": 1635952880
}
Create events using the Sensu agent
The Sensu agent is a powerful event producer and monitoring automation tool. You can use Sensu agents to produce events automatically using service checks and metric checks. Sensu agents can also act as a collector for metrics throughout your infrastructure.
Create events with the core/v2/events API endpoints
You can send events directly to the Sensu observability pipeline using the core/v2 API events endpoint. To create an event, send a JSON event definition with a PUT request to core/v2/events.
If you use the core/v2/events API to create a new event referencing an entity that does not already exist, the sensu-backend will automatically create a proxy entity in the same namespace when the event is published.
NOTE: An agent cannot belong to, execute checks in, or create events in more than one namespace.
Manage events
You can manage events using the Sensu web UI, core/v2/events API endpoints, and sensuctl command line tool.
View events
To list all events:
sensuctl event list
To show event details in the default output format (tabular):
sensuctl event info <entity-name> <check-name>
NOTE: Metrics data points are not included in events retrieved with sensuctl event info
— these events include check output text rather than a set of metrics points.
With both the list
and info
commands, you can specify an output format using the --format
flag:
yaml
orwrapped-json
formats for use withsensuctl create
json
format for use with core/v2/events API endpoints
sensuctl event info entity-name check-name --format yaml
sensuctl event info entity-name check-name --format wrapped-json
sensuctl event info entity-name check-name --format json
PRO TIP: You can also view complete resource definitions in the Sensu web UI.
Delete events
To delete an event:
sensuctl event delete entity-name check-name
You can use the --skip-confirm
flag to skip the confirmation step:
sensuctl event delete entity-name check-name --skip-confirm
You should receive a confirmation message upon success:
Deleted
Resolve events
You can use sensuctl to change the status of an event to 0
(OK).
Events resolved by sensuctl include the output message Resolved manually by sensuctl
.
sensuctl event resolve entity-name check-name
You should receive a confirmation message upon success:
Resolved
Use event data
Observability data in events is a powerful tool for automating monitoring workflows.
For example, the state
attribute provides handlers with a high-level description of check status.
Filtering events based on this attribute can help reduce alert fatigue.
State attribute
The state
event attribute adds meaning to the check status:
passing
means the check status is0
(OK).failing
means the check status is non-zero (WARNING or CRITICAL).flapping
indicates an unsteady state in which the check result status (determined based on per-check high flap threshold and low flap threshold attributes) is not settling onpassing
orfailing
according to the flap detection algorithm.
Flapping typically indicates intermittent problems with an entity, provided your low and high flap threshold settings are properly configured. Although some teams choose to filter out flapping events to reduce unactionable alerts, we suggest sending flapping events to a designated handler for later review. If you repeatedly observe events in flapping state, Sensu’s per-check flap threshold configuration allows you to adjust the sensitivity of the flap detection algorithm.
Flap detection algorithm
Sensu uses the same flap detection algorithm as Nagios.
Every time you run a check, Sensu records whether the status
value changed since the previous check.
Sensu stores the last 21 status
values and uses them to calculate the percent state change for the entity/check pair.
Then, Sensu’s algorithm applies a weight to these status changes: more recent changes have more value than older changes.
After calculating the weighted total percent state change, Sensu compares it with the high flap threshold and low flap threshold set in the check attributes.
- If the entity was not already flapping and the weighted total percent state change for the entity/check pair is greater than or equal to the
high_flap_threshold
setting, the entity has started flapping. - If the entity was already flapping and the weighted total percent state change for the entity/check pair is less than the
low_flap_threshold
setting, the entity has stopped flapping.
Depending on the result of this comparison, Sensu will trigger the appropriate event filters based on check attributes like event.check.high_flap_threshold
and event.check.low_flap_threshold
.
Occurrences and occurrences watermark
The occurrences
and occurrences_watermark
event attributes give you context about recent events for a given entity and check.
You can use these attributes within event filters to fine-tune incident notifications and reduce alert fatigue.
Starting at 1
, the occurrences
attribute increments for events with the same status as the preceding event (OK, WARNING, CRITICAL, or UNKNOWN) and resets whenever the status changes.
You can use the occurrences
attribute to create a state-change-only filter or an interval filter.
The occurrences_watermark
attribute gives you useful information when looking at events that change status between non-OK (WARNING, CRITICAL, or UNKNOWN) and OK.
For these resolution events, the occurrences_watermark
attribute tells you the number of preceding events with a non-OK status.
Sensu resets occurrences_watermark
to 1
on the first non-OK event.
Within a sequence of only OK or only non-OK events, Sensu increments occurrences_watermark
when the occurrences
attribute is greater than the preceding occurrences_watermark
.
The following table shows the occurrences attributes for a series of example events:
event sequence | occurrences |
occurrences_watermark |
---|---|---|
1. OK event | occurrences: 1 |
occurrences_watermark: 1 |
2. OK event | occurrences: 2 |
occurrences_watermark: 2 |
3. WARNING event | occurrences: 1 |
occurrences_watermark: 1 |
4. WARNING event | occurrences: 2 |
occurrences_watermark: 2 |
5. WARNING event | occurrences: 3 |
occurrences_watermark: 3 |
6. CRITICAL event | occurrences: 1 |
occurrences_watermark: 3 |
7. CRITICAL event | occurrences: 2 |
occurrences_watermark: 3 |
8. CRITICAL event | occurrences: 3 |
occurrences_watermark: 3 |
9. CRITICAL event | occurrences: 4 |
occurrences_watermark: 4 |
10. OK event | occurrences: 1 |
occurrences_watermark: 4 |
11. CRITICAL event | occurrences: 1 |
occurrences_watermark: 1 |
Event specification
Top-level attributes
api_version | |
---|---|
description | Top-level attribute that specifies the Sensu API group and version. For events in this version of Sensu, api_version should always be core/v2 . |
required | Required for events in wrapped-json or yaml format for use with sensuctl create . |
type | String |
example | YMLJSON
|
metadata | |
---|---|
description | Top-level scope that contains the event namespace and created_by field. The metadata map is always at the top level of the check definition. This means that in wrapped-json and yaml formats, the metadata scope occurs outside the spec scope. Review the metadata attributes for details. |
required | Required for events in wrapped-json or yaml format for use with sensuctl create . |
type | Map of key-value pairs |
example | YMLJSON
|
pipelines | |
---|---|
description | Name, type, and API version for the pipelines used to process the observability event. Sensu automatically populates the pipelines attributes when the event is created or updated. Read pipelines attributes for more information. |
required | false |
type | Array |
example | YMLJSON
|
spec | |
---|---|
description | Top-level map that includes the event spec attributes. |
required | Required for events in wrapped-json or yaml format for use with sensuctl create . |
type | Map of key-value pairs |
example | YMLJSON
|
type | |
---|---|
description | Top-level attribute that specifies the sensuctl create resource type. Events should always be type Event . |
required | Required for events in wrapped-json or yaml format for use with sensuctl create . |
type | String |
example | YMLJSON
|
Metadata attributes
created_by | |
---|---|
description | Username of the Sensu user who created the event or last updated the event. Sensu automatically populates the created_by field when the event is created or updated. |
required | false |
type | String |
example | YMLJSON
|
namespace | |
---|---|
description | Sensu RBAC namespace that the event belongs to. |
required | false |
type | String |
default | default |
example | YMLJSON
|
Pipelines attributes
api_version | |
---|---|
description | The Sensu API group and version for the pipeline. Sensu automatically populates the pipelines api_version field when the event is created or updated. For pipelines in this version of Sensu, the api_version is core/v2 . |
required | false |
type | String |
default | null |
example | YMLJSON
|
name | |
---|---|
description | Name of the Sensu pipeline used to process the observability event. Sensu automatically populates the pipeline name field when the event is created or updated. |
required | false |
type | String |
default | null |
example | YMLJSON
|
type | |
---|---|
description | The sensuctl create resource type for the pipeline. Sensu automatically populates the pipelines type field when the event is created or updated. Pipeline resources are always type Pipeline . |
required | false |
type | String |
default | null |
example | YMLJSON
|
Spec attributes
check | |
---|---|
description | Check definition used to create the event and information about the status and history of the event. The check scope includes attributes described in the event specification and the check specification. |
type | Map |
required | true |
example | YMLJSON
|
entity | |
---|---|
description | Entity attributes from the originating entity (agent or proxy). For events created with the core/v2/events API, if the event’s entity does not already exist, the sensu-backend automatically creates a proxy entity when the event is published. |
type | Map |
required | true |
example | YMLJSON
|
id | |
---|---|
description | Universally unique identifier (UUID) for the event. Logged as event_id .Sensu automatically populates the id value for the event. |
required | false |
type | String |
example | YMLJSON
|
metrics | |
---|---|
description | Metrics collected by the entity in Sensu metric format. Review the metrics attributes. |
type | Map |
required | false |
example | YMLJSON
|
sequence | |
---|---|
description | Event sequence number. The Sensu agent sets the sequence to 1 at startup, then increments the sequence by 1 for every successive check execution or keepalive event. If the agent restarts or reconnects to another backend, the sequence value resets to 1. A sequence value of 0 indicates that an outdated or non-conforming agent generated the event. Sensu only increments the sequence for agent-executed events. Sensu does not update the sequence for events created with the core/v2/events API. |
required | false |
type | Integer |
example | YMLJSON
|
timestamp | |
---|---|
description | Time that the event occurred. In seconds since the Unix epoch. Sensu automatically populates the timestamp value for the event. For events created with the core/v2/events API, you can specify a timestamp value in the request body. |
required | false |
type | Integer |
default | Time that the event occurred |
example | YMLJSON
|
Check attributes
Sensu events include a check
scope that contains information about how the event was created, including any attributes defined in the check specification, and information about the event and its history, including the attributes defined below.
duration | |
---|---|
description | Command execution time. In seconds. |
required | false |
type | Float |
example | YMLJSON
|
executed | |
---|---|
description | Time at which the check request was executed. In seconds since the Unix epoch. The difference between a request’s issued and executed values is the request latency.For agent-executed checks, Sensu automatically populates the executed value. For events created with the core/v2/events API, the default executed value is 0 unless you specify a value in the request body. |
required | false |
type | Integer |
example | YMLJSON
|
history | |
---|---|
description | Check status history for the last 21 check executions. Read history attributes. Sensu automatically populates the history attributes with check execution data. To store more than the last 21 check executions, use one of our long-term event storage integrations. |
required | false |
type | Array |
example | YMLJSON
|
is_silenced | |
---|---|
description | If true , the event was silenced at the time of processing. Otherwise, false . If true , the event. Check definitions also list the silenced entries that match the event in the silenced array. |
required | false |
type | Boolean |
example | YMLJSON
|
issued | |
---|---|
description | Time that the check request was issued. In seconds since the Unix epoch. The difference between a request’s issued and executed values is the request latency.For agent-executed checks, Sensu automatically populates the issued value. For events created with the core/v2/events API, the default issued value is 0 unless you specify a value in the request body. |
required | false |
type | Integer |
example | YMLJSON
|
last_ok | |
---|---|
description | Last time that the check returned an OK status (0 ). In seconds since the Unix epoch.For agent-executed checks, Sensu automatically populates the last_ok value. For events created with the core/v2/events API, the last_ok attribute will default to 0 even if you specify OK status in the request body. |
required | false |
type | Integer |
example | YMLJSON
|
occurrences | |
---|---|
description | Number of preceding events with the same status as the current event (OK, WARNING, CRITICAL, or UNKNOWN). Starting at 1 , the occurrences attribute increments for events with the same status as the preceding event and resets whenever the status changes. Read Use event data for more information.Sensu automatically populates the occurrences value. For events created with the core/v2/events API, Sensu overwrites any occurences value you specify in the request body with the correct value. |
required | false |
type | Integer greater than 0 |
example | YMLJSON
|
occurrences_watermark | |
---|---|
description | For incident and resolution events, the number of preceding events with an OK status (for incident events) or non-OK status (for resolution events). The occurrences_watermark attribute gives you useful information when looking at events that change status between OK (0 )and non-OK (1 -WARNING, 2 -CRITICAL, or UNKNOWN).Sensu resets occurrences_watermark to 1 whenever an event for a given entity and check transitions between OK and non-OK. Within a sequence of only OK or only non-OK events, Sensu increments occurrences_watermark only when the occurrences attribute is greater than the preceding occurrences_watermark . Read Use event data for more information.Sensu automatically populates the occurrences_watermark value. For events created with the core/v2/events API, Sensu overwrites any occurences_watermark value you specify in the request body with the correct value. |
required | false |
type | Integer greater than 0 |
example | YMLJSON
|
output | |
---|---|
description | Output from the execution of the check command. |
required | false |
type | String |
example | YMLJSON
|
processed_by | |
---|---|
description | The name of the agent that processed the event. Useful for determining which agent processed an event executed by a proxy check request or a POST request to the events API. |
required | false |
type | String |
example | YMLJSON
|
silenced | |
---|---|
description | Array of silencing entries that match the event. The silenced attribute is only present for events if one or more silencing entries matched the event at time of processing. If the silenced attribute is not present in an event, the event was not silenced at the time of processing. |
required | false |
type | Array |
example | YMLJSON
|
state | |
---|---|
description | State of the check: passing (status 0 ), failing (status other than 0 ), or flapping . Use the low_flap_threshold and high_flap_threshold check attributes to configure flapping state detection.Sensu automatically populates the state based on the status . |
required | false |
type | String |
example | YMLJSON
|
status | |
---|---|
description | Exit status code produced by the check.
0 , 1 , or 2 indicate an UNKNOWN or custom status.For agent-executed checks, Sensu automatically populates the status value based on the check result. For events created with the core/v2/events API, Sensu assumes the status is 0 (OK) unless you specify a non-zero value in the request body. |
required | false |
type | Integer |
example | YMLJSON
|
total_state_change | |
---|---|
description | Total state change percentage for the check’s history. For agent-executed checks, Sensu automatically populates the total_state_change value. For events created with the core/v2/events API, the total_state_change attribute will default to 0 even if you specify a different value or change the status value in the request body. |
required | false |
type | Integer |
example | YMLJSON
|
History attributes
executed | |
---|---|
description | Time at which the check request was executed. In seconds since the Unix epoch. Sensu automatically populates the executed value with check execution data. For events created with the core/v2/events API, the executed default value is 0 . |
required | false |
type | Integer |
example | YMLJSON
|
status | |
---|---|
description | Exit status code produced by the check.
0 , 1 , or 2 indicate an UNKNOWN or custom status.Sensu automatically populates the status value with check execution data. |
required | false |
type | Integer |
example | YMLJSON
|
Metrics attributes
handlers | |
---|---|
description | Array of Sensu handlers to use for events created by the check. Each array item must be a string. |
required | false |
type | Array |
example | YMLJSON
|
points | |
---|---|
description | Metrics data points, including a name, timestamp, value, and tags. Read points attributes. |
required | false |
type | Array |
example | YMLJSON
|
Points attributes
name | |
---|---|
description | Metric name in the format $entity.$check.$metric where $entity is the entity name, $check is the check name, and $metric is the metric name. |
required | false |
type | String |
example | YMLJSON
|
tags | |
---|---|
description | Optional tags to include with the metric. Each element of the array must be a hash that contains two key-value pairs: the name of the tag and the value . Both values of the pairs must be strings. |
required | false |
type | Array |
example | YMLJSON
|
timestamp | |
---|---|
description | Time at which the metric was collected. In seconds since the Unix epoch. Sensu automatically populates the timestamp values for metrics data points. |
required | false |
type | Integer |
example | YMLJSON
|
value | |
---|---|
description | Metric value. |
required | false |
type | Float |
example | YMLJSON
|