This page documents all of the API endpoints for each Druid service type.
## Table of Contents
* [Common](#common)
* [Coordinator](#coordinator)
* [Overlord](#overlord)
* [MiddleManager](#middlemanager)
* [Peon](#peon)
* [Broker](#broker)
* [Historical](#historical)
## Common
The following endpoints are supported by all nodes.
### Node information
#### GET
*`/status`
Returns the Druid version, loaded extensions, memory used, total memory and other useful information about the node.
*`/status/health`
An endpoint that always returns a boolean "true" value with a 200 OK response, useful for automated health checks.
*`/status/properties`
Returns the current configuration properties of the node.
## Coordinator
### Leadership
#### GET
*`/druid/coordinator/v1/leader`
Returns the current leader coordinator of the cluster.
*`/druid/coordinator/v1/isLeader`
Returns true if the coordinator receiving the request is the current leader.
### Segment Loading
#### GET
Returns a JSON object with field "leader", either true or false, indicating if this server is the current leader
coordinator of the cluster. In addition, returns HTTP 200 if the server is the current leader and HTTP 404 if not.
This is suitable for use as a load balancer status check if you only want the active leader to be considered in-service
at the load balancer.
*`/druid/coordinator/v1/loadstatus`
Returns the percentage of segments actually loaded in the cluster versus segments that should be loaded in the cluster.
*`/druid/coordinator/v1/loadstatus?simple`
Returns the number of segments left to load until segments that should be loaded in the cluster are available for queries. This does not include replication.
*`/druid/coordinator/v1/loadstatus?full`
Returns the number of segments left to load in each tier until segments that should be loaded in the cluster are all available. This includes replication.
*`/druid/coordinator/v1/loadqueue`
Returns the ids of segments to load and drop for each historical node.
*`/druid/coordinator/v1/loadqueue?simple`
Returns the number of segments to load and drop, as well as the total segment load and drop size in bytes for each historical node.
*`/druid/coordinator/v1/loadqueue?full`
Returns the serialized JSON of segments to load and drop for each historical node.
### Metadata store information
#### GET
*`/druid/coordinator/v1/metadata/datasources`
Returns a list of the names of enabled datasources in the cluster.
Returns a list of all segments, overlapping with any of given intervals, for a datasource as stored in the metadata store. Request body is array of string intervals like [interval1, interval2,...] for example ["2012-01-01T00:00:00.000/2012-01-03T00:00:00.000", "2012-01-05T00:00:00.000/2012-01-07T00:00:00.000"]
Returns a list of all segments, overlapping with any of given intervals, for a datasource with the full segment metadata as stored in the metadata store. Request body is array of string intervals like [interval1, interval2,...] for example ["2012-01-01T00:00:00.000/2012-01-03T00:00:00.000", "2012-01-05T00:00:00.000/2012-01-07T00:00:00.000"]
### Datasources
#### GET
*`/druid/coordinator/v1/datasources`
Returns a list of datasource names found in the cluster.
*`/druid/coordinator/v1/datasources?simple`
Returns a list of JSON objects containing the name and properties of datasources found in the cluster. Properties include segment count, total segment byte size, minTime, and maxTime.
*`/druid/coordinator/v1/datasources?full`
Returns a list of datasource names found in the cluster with all metadata about those datasources.
Returns a JSON object containing the name and properties of a datasource. Properties include segment count, total segment byte size, minTime, and maxTime.
Returns a set of segment ids for an ISO8601 interval. Note that {interval} parameters are delimited by a `_` instead of a `/` (e.g., 2016-06-27_2016-06-28).
Returns a map of segment intervals contained within the specified interval to a JSON object containing the total byte size of segments and number of segments for an interval.
Returns a map of segment intervals contained within the specified interval to a map of segment metadata to a set of server names that contain the segment for an interval.
Returns audit history of rules for all datasources. default value of interval can be specified by setting `druid.audit.manager.auditHistoryMillis` (1 week if not configured) in coordinator runtime.properties
*`/druid/coordinator/v1/rules/history?count=<n>`
Returns last <n> entries of audit history of rules for all datasources.
Returns audit history of rules for a specified datasource. default value of interval can be specified by setting `druid.audit.manager.auditHistoryMillis` (1 week if not configured) in coordinator runtime.properties
Creates or updates the compaction config for a dataSource. See [Compaction Configuration](../configuration/coordinator.html#compaction-configuration) for configuration details.
The MiddleManager does not have any API endpoints beyond the [common endpoints](#common).
## Peon
The Peon does not have any API endpoints beyond the [common endpoints](#common).
## Broker
### Datasource Information
#### GET
*`/druid/v2/datasources`
Returns a list of queryable datasources.
*`/druid/v2/datasources/{dataSourceName}`
Returns the dimensions and metrics of the datasource. Optionally, you can provide request parameter "full" to get list of served intervals with dimensions and metrics being served for those intervals. You can also provide request param "interval" explicitly to refer to a particular interval.
If no interval is specified, a default interval spanning a configurable period before the current time will be used. The duration of this interval is specified in ISO8601 format via:
Returns segment information lists including server locations for the given datasource and intervals. If "numCandidates" is not specified, it will return all servers for each interval.
### Load Status
#### GET
*`/druid/broker/v1/loadstatus`
Returns a flag indicating if the broker knows about all segments in Zookeeper. This can be used to know when a broker node is ready to be queried after a restart.
### Queries
#### POST
*`/druid/v2/`
The endpoint for submitting queries. Accepts an option `?pretty` that pretty prints the results.
*`/druid/v2/candidates/`
Returns segment information lists including server locations for the given query..
## Historical
### Segment Loading
#### GET
*`/druid/historical/v1/loadstatus`
Returns JSON of the form `{"cacheInitialized":<value>}`, where value is either `true` or `false` indicating if all
segments in the local cache have been loaded. This can be used to know when a historical node is ready
to be queried after a restart.
*`/druid/historical/v1/readiness`
Similar to `/druid/historical/v1/loadstatus`, but instead of returning JSON with a flag, responses 200 OK if segments
in the local cache have been loaded, and 503 SERVICE UNAVAILABLE, if they haven't.