# HashiCorp Consul Cluster by HTTP ## Overview The template to monitor HashiCorp Consul by Zabbix that works without any external scripts. Most of the metrics are collected in one go, thanks to Zabbix bulk data collection. Template `HashiCorp Consul Cluster by HTTP` — collects metrics by HTTP agent from API endpoints. More information about metrics you can find in [official documentation](https://www.consul.io/docs/agent/telemetry). ## Requirements Zabbix version: 7.0 and higher. ## Tested versions This template has been tested on: - HashiCorp Consul 1.10.0 ## Configuration > Zabbix should be configured according to the instructions in the [Templates out of the box](https://www.zabbix.com/documentation/7.0/manual/config/templates_out_of_the_box) section. ## Setup Template need to use Authorization via API token. Don't forget to change macros {$CONSUL.CLUSTER.URL}, {$CONSUL.TOKEN}. Also, see the Macros section for a list of macros used to set trigger values. This template support [Consul namespaces](https://www.consul.io/docs/enterprise/namespaces). You can set macro {$CONSUL.NAMESPACE}, if you are interested in only one service namespace. Do not specify this macro to get all of services. In case of Open Source version leave this macro empty. *NOTE.* Some metrics may not be collected depending on your HashiCorp Consul instance version and configuration. *NOTE.* You maybe are interested in Envoy Proxy by HTTP [template](../../envoy_proxy_http). ### Macros used |Name|Description|Default| |----|-----------|-------| |{$CONSUL.CLUSTER.URL}|

Consul cluster URL.

|`http://localhost:8500`| |{$CONSUL.TOKEN}|

Consul auth token.

|``| |{$CONSUL.NAMESPACE}|

Consul service namespace. Enterprise only, in case of Open Source version leave this macro empty. Do not specify this macro to get all of services.

|| |{$CONSUL.API.SCHEME}|

Consul API scheme. Using in node LLD.

|`http`| |{$CONSUL.API.PORT}|

Consul API port. Using in node LLD.

|`8500`| |{$CONSUL.LLD.FILTER.NODE_NAME.MATCHES}|

Filter of discoverable discovered nodes.

|`.*`| |{$CONSUL.LLD.FILTER.NODE_NAME.NOT_MATCHES}|

Filter to exclude discovered nodes.

|`CHANGE IF NEEDED`| |{$CONSUL.LLD.FILTER.SERVICE_NAME.MATCHES}|

Filter of discoverable discovered services.

|`.*`| |{$CONSUL.LLD.FILTER.SERVICE_NAME.NOT_MATCHES}|

Filter to exclude discovered services.

|`CHANGE IF NEEDED`| |{$CONSUL.SERVICE_NODES.CRITICAL.MAX.AVG}|

Maximum number of service nodes in status 'critical' for trigger expression. Can be used with context.

|`0`| ### Items |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Consul cluster: Cluster leader|

Current leader address.

|HTTP agent|consul.get_leader

**Preprocessing**

| |Consul cluster: Nodes: peers|

The number of Raft peers for the datacenter in which the agent is running.

|HTTP agent|consul.get_peers

**Preprocessing**

| |Consul cluster: Get nodes|

Catalog of nodes registered in a given datacenter.

|HTTP agent|consul.get_nodes

**Preprocessing**

| |Consul cluster: Get nodes Serf health status|

Get Serf Health Status for all agents in cluster.

|HTTP agent|consul.get_cluster_serf

**Preprocessing**

| |Consul: Nodes: total|

Number of nodes on current dc.

|Dependent item|consul.nodes_total

**Preprocessing**

| |Consul: Nodes: passing|

Number of agents on current dc with serf health status 'passing'.

|Dependent item|consul.nodes_passing

**Preprocessing**

| |Consul: Nodes: critical|

Number of agents on current dc with serf health status 'critical'.

|Dependent item|consul.nodes_critical

**Preprocessing**

| |Consul: Nodes: warning|

Number of agents on current dc with serf health status 'warning'.

|Dependent item|consul.nodes_warning

**Preprocessing**

| |Consul cluster: Get services|

Catalog of services registered in a given datacenter.

|HTTP agent|consul.get_catalog_services

**Preprocessing**

| |Consul: Services: total|

Number of services on current dc.

|Dependent item|consul.services_total

**Preprocessing**

| ### Triggers |Name|Description|Expression|Severity|Dependencies and additional info| |----|-----------|----------|--------|--------------------------------| |Consul cluster: Leader has been changed|

Consul cluster version has changed. Acknowledge to close the problem manually.

|`last(/HashiCorp Consul Cluster by HTTP/consul.get_leader,#1)<>last(/HashiCorp Consul Cluster by HTTP/consul.get_leader,#2) and length(last(/HashiCorp Consul Cluster by HTTP/consul.get_leader))>0`|Info|**Manual close**: Yes| |Consul: One or more nodes in cluster in 'critical' state|

One or more agents on current dc with serf health status 'critical'.

|`last(/HashiCorp Consul Cluster by HTTP/consul.nodes_critical)>0`|Average|| |Consul: One or more nodes in cluster in 'warning' state|

One or more agents on current dc with serf health status 'warning'.

|`last(/HashiCorp Consul Cluster by HTTP/consul.nodes_warning)>0`|Warning|| ### LLD rule Consul cluster nodes discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Consul cluster nodes discovery||Dependent item|consul.lld_nodes

**Preprocessing**

| ### Item prototypes for Consul cluster nodes discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Consul: Node ["{#NODE_NAME}"]: Serf Health|

Node Serf Health Status.

|Dependent item|consul.serf.health["{#NODE_NAME}"]

**Preprocessing**

| ### LLD rule Consul cluster services discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Consul cluster services discovery||Dependent item|consul.lld_services

**Preprocessing**

| ### Item prototypes for Consul cluster services discovery |Name|Description|Type|Key and additional info| |----|-----------|----|-----------------------| |Consul: Service ["{#SERVICE_NAME}"]: Nodes passing|

The number of nodes with service status `passing` from those registered.

|Dependent item|consul.service.nodes_passing["{#SERVICE_NAME}"]

**Preprocessing**

| |Consul: Service ["{#SERVICE_NAME}"]: Nodes warning|

The number of nodes with service status `warning` from those registered.

|Dependent item|consul.service.nodes_warning["{#SERVICE_NAME}"]

**Preprocessing**

| |Consul: Service ["{#SERVICE_NAME}"]: Nodes critical|

The number of nodes with service status `critical` from those registered.

|Dependent item|consul.service.nodes_critical["{#SERVICE_NAME}"]

**Preprocessing**

| |Consul cluster: ["{#SERVICE_NAME}"]: Get raw service state|

Retrieve service instances providing the service indicated on the path.

|HTTP agent|consul.get_service_stats["{#SERVICE_NAME}"]

**Preprocessing**

| ### Trigger prototypes for Consul cluster services discovery |Name|Description|Expression|Severity|Dependencies and additional info| |----|-----------|----------|--------|--------------------------------| |Consul: Service ["{#SERVICE_NAME}"]: Too many nodes with service status 'critical'|

One or more nodes with service status 'critical'.

|`last(/HashiCorp Consul Cluster by HTTP/consul.service.nodes_critical["{#SERVICE_NAME}"])>{$CONSUL.CLUSTER.SERVICE_NODES.CRITICAL.MAX.AVG:"{#SERVICE_NAME}"}`|Average|| ## Feedback Please report any issues with the template at [`https://support.zabbix.com`](https://support.zabbix.com) You can also provide feedback, discuss the template, or ask for help at [`ZABBIX forums`](https://www.zabbix.com/forum/zabbix-suggestions-and-feedback)