Vault
/sys/health
The /sys/health endpoint is used to check the health status of Vault.
Read health information
This endpoint returns the health status of Vault. This matches the semantics of a Consul HTTP health check and provides a simple way to monitor the health of a Vault instance.
| Method | Path | 
|---|---|
| HEAD | /sys/health | 
| GET | /sys/health | 
The default status codes are:
- 200if initialized, unsealed, and active
- 429if unsealed and standby
- 472if disaster recovery mode replication secondary and active
- 473if performance standby
- 501if not initialized
- 503if sealed
Parameters
- standbyok- (bool: false)– Specifies if being a standby should still return the active status code instead of the standby status code. This is useful when Vault is behind a non-configurable load balancer that just wants a 200-level response. This will not apply if the node is a performance standby.
- perfstandbyok- (bool: false)– Specifies if being a performance standby should still return the active status code instead of the performance standby status code. This is useful when Vault is behind a non-configurable load balancer that just wants a 200-level response.
- activecode- (int: 200)– Specifies the status code that should be returned for an active node.
- standbycode- (int: 429)– Specifies the status code that should be returned for a standby node.
- drsecondarycode- (int: 472)– Specifies the status code that should be returned for a DR secondary node.
- performancestandbycode- (int: 473)– Specifies the status code that should be returned for a performance standby node.
- sealedcode- (int: 503)– Specifies the status code that should be returned for a sealed node.
- uninitcode- (int: 501)– Specifies the status code that should be returned for a uninitialized node.
Sample request
$ curl \
    http://127.0.0.1:8200/v1/sys/health
Sample response
This response is only returned for a GET request.
Note: replication_performance_mode and replication_dr_mode reflect the state of
the active node in the cluster; if you are querying it for a standby that has
just come up, it can take a small time for the active node to inform the
standby of its status.
{
  "initialized": true,
  "sealed": false,
  "standby": false,
  "performance_standby": false,
  "replication_performance_mode": "disabled",
  "replication_dr_mode": "disabled",
  "server_time_utc": 1516639589,
  "version": "0.9.2",
  "cluster_name": "vault-cluster-3bd69ca2",
  "cluster_id": "00af5aa8-c87d-b5fc-e82e-97cd8dfaf731"
}
Sample request to customize the status code being returned
$ curl -i https://127.0.0.1:8200/v1/sys/health\?drsecondarycode\=200
HTTP/2 200
cache-control: no-store
content-type: application/json
strict-transport-security: max-age=31536000; includeSubDomains
content-length: 364
date: Wed, 26 Jan 2022 09:21:13 GMT
Sample response
This response is only returned for a GET request.
Note: replication_performance_mode and replication_dr_mode reflect the state of
the active node in the cluster; if you are querying it for a standby that has
just come up, it may take time for the active node to inform the
standby of its status.
{
  "initialized": true,
  "sealed": false,
  "standby": false,
  "performance_standby": false,
  "replication_performance_mode": "disabled",
  "replication_dr_mode": "secondary",
  "server_time_utc": 1643188873,
  "version": "1.9.0+prem",
  "cluster_name": "SECONDARY",
  "cluster_id": "d2fbb13b-0830-70a3-4751-57b6b6d95d01",
  "last_wal":13,
  "license":{"state":"none","expiry_time":"","terminated":false}
}