2014-02-07 16:41:03 -08:00
|
|
|
---
|
|
|
|
layout: "docs"
|
|
|
|
page_title: "RPC"
|
|
|
|
sidebar_current: "docs-agent-rpc"
|
|
|
|
---
|
|
|
|
|
|
|
|
# RPC Protocol
|
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
The Consul agent provides a complete RPC mechanism that can
|
2014-02-07 16:41:03 -08:00
|
|
|
be used to control the agent programmatically. This RPC
|
|
|
|
mechanism is the same one used by the CLI, but can be
|
|
|
|
used by other applications to easily leverage the power
|
2014-04-09 11:06:27 -07:00
|
|
|
of Consul without directly embedding. It is important to note
|
|
|
|
that the RPC protocol does not support all the same operations
|
|
|
|
as the [HTTP API](/docs/agent/http.html).
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
## Implementation Details
|
|
|
|
|
|
|
|
The RPC protocol is implemented using [MsgPack](http://msgpack.org/)
|
|
|
|
over TCP. This choice is driven by the fact that all operating
|
|
|
|
systems support TCP, and MsgPack provides a fast serialization format
|
|
|
|
that is broadly available across languages.
|
|
|
|
|
|
|
|
All RPC requests have a request header, and some requests have
|
|
|
|
a request body. The request header looks like:
|
|
|
|
|
|
|
|
```
|
|
|
|
{"Command": "Handshake", "Seq": 0}
|
|
|
|
```
|
|
|
|
|
|
|
|
All responses have a response header, and some may contain
|
|
|
|
a response body. The response header looks like:
|
|
|
|
|
|
|
|
```
|
|
|
|
{"Seq": 0, "Error": ""}
|
|
|
|
```
|
|
|
|
|
|
|
|
The `Command` is used to specify what command the server should
|
|
|
|
run, and the `Seq` is used to track the request. Responses are
|
|
|
|
tagged with the same `Seq` as the request. This allows for some
|
|
|
|
concurrency on the server side, as requests are not purely FIFO.
|
|
|
|
Thus, the `Seq` value should not be re-used between commands.
|
|
|
|
All responses may be accompanied by an error.
|
|
|
|
|
|
|
|
Possible commands include:
|
|
|
|
|
|
|
|
* handshake - Used to initialize the connection, set the version
|
|
|
|
* force-leave - Removes a failed node from the cluster
|
2014-02-18 15:30:07 -08:00
|
|
|
* join - Requests Consul join another node
|
|
|
|
* members-lan - Returns the list of lan members
|
|
|
|
* members-wan - Returns the list of wan members
|
2014-02-07 16:41:03 -08:00
|
|
|
* monitor - Starts streaming logs over the connection
|
2014-02-18 15:30:07 -08:00
|
|
|
* stop - Stops streaming logs
|
|
|
|
* leave - Consul agent performs a graceful leave and shutdown
|
2014-02-23 17:09:59 -08:00
|
|
|
* stats - Provides various debugging statistics
|
2014-06-11 10:54:36 -07:00
|
|
|
* reload - Triggers a configuration reload
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
Below each command is documented along with any request or
|
|
|
|
response body that is applicable.
|
|
|
|
|
|
|
|
### handshake
|
|
|
|
|
|
|
|
The handshake MUST be the first command that is sent, as it informs
|
|
|
|
the server which version the client is using.
|
|
|
|
|
|
|
|
The request header must be followed with a handshake body, like:
|
|
|
|
|
|
|
|
```
|
|
|
|
{"Version": 1}
|
|
|
|
```
|
|
|
|
|
|
|
|
The body specifies the IPC version being used, however only version
|
|
|
|
1 is currently supported. This is to ensure backwards compatibility
|
|
|
|
in the future.
|
|
|
|
|
|
|
|
There is no special response body, but the client should wait for the
|
|
|
|
response and check for an error.
|
|
|
|
|
|
|
|
### force-leave
|
|
|
|
|
|
|
|
This command is used to remove failed nodes from a cluster. It takes
|
|
|
|
the following body:
|
|
|
|
|
|
|
|
```
|
|
|
|
{"Node": "failed-node-name"}
|
|
|
|
```
|
|
|
|
|
|
|
|
There is no special response body.
|
|
|
|
|
|
|
|
### join
|
|
|
|
|
|
|
|
This command is used to join an existing cluster using a known node.
|
|
|
|
It takes the following body:
|
|
|
|
|
|
|
|
```
|
2014-02-18 15:30:07 -08:00
|
|
|
{"Existing": ["192.168.0.1:6000", "192.168.0.2:6000"], "WAN": false}
|
2014-02-07 16:41:03 -08:00
|
|
|
```
|
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
The `Existing` nodes are each contacted, and `WAN` controls if we are adding a
|
|
|
|
WAN member or LAN member. LAN members are expected to be in the same datacenter,
|
|
|
|
and should be accessible at relatively low latencies. WAN members are expected to
|
|
|
|
be operating in different datacenters, with relatively high access latencies. It is
|
|
|
|
important that only agents running in "server" mode are able to join nodes over the
|
|
|
|
WAN.
|
|
|
|
|
|
|
|
The response body in addition to the header is returned. The body looks like:
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
```
|
|
|
|
{"Num": 2}
|
|
|
|
```
|
|
|
|
|
|
|
|
The body returns the number of nodes successfully joined.
|
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
### members-lan
|
|
|
|
|
|
|
|
The members-lan command is used to return all the known lan members and associated
|
|
|
|
information. All agents will respond to this command.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
There is no request body, but the response looks like:
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
```
|
|
|
|
{"Members": [
|
|
|
|
{
|
|
|
|
"Name": "TestNode"
|
|
|
|
"Addr": [127, 0, 0, 1],
|
|
|
|
"Port": 5000,
|
|
|
|
"Tags": {
|
|
|
|
"role": "test"
|
|
|
|
},
|
|
|
|
"Status": "alive",
|
|
|
|
"ProtocolMin": 0,
|
|
|
|
"ProtocolMax": 3,
|
|
|
|
"ProtocolCur": 2,
|
|
|
|
"DelegateMin": 0,
|
|
|
|
"DelegateMax": 1,
|
|
|
|
"DelegateCur": 1,
|
|
|
|
},
|
|
|
|
...]
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
### members-wan
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
The members-wan command is used to return all the known wan members and associated
|
|
|
|
information. Only agents in server mode will respond to this command.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
There is no request body, and the response is the same as `members-lan`
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
### monitor
|
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
The monitor command subscribes the channel to log messages from the Agent.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
The request is like:
|
|
|
|
|
|
|
|
```
|
|
|
|
{"LogLevel": "DEBUG"}
|
|
|
|
```
|
|
|
|
|
|
|
|
This subscribes the client to all messages of at least DEBUG level.
|
|
|
|
|
|
|
|
The server will respond with a standard response header indicating if the monitor
|
|
|
|
was successful. However, now as logs occur they will be sent and tagged with
|
|
|
|
the same `Seq` as the monitor command that matches.
|
|
|
|
|
|
|
|
Assume we issued the previous monitor command with Seq `50`,
|
|
|
|
we may start getting messages like:
|
|
|
|
|
|
|
|
```
|
|
|
|
{"Seq": 50, "Error": ""}
|
|
|
|
{"Log": "2013/12/03 13:06:53 [INFO] agent: Received event: member-join"}
|
|
|
|
```
|
|
|
|
|
2014-04-30 15:26:07 -04:00
|
|
|
It is important to realize that these messages are sent asynchronously,
|
2014-02-07 16:41:03 -08:00
|
|
|
and not in response to any command. That means if a client is streaming
|
|
|
|
commands, there may be logs streamed while a client is waiting for a
|
|
|
|
response to a command. This is why the `Seq` must be used to pair requests
|
|
|
|
with their corresponding responses.
|
|
|
|
|
|
|
|
The client can only be subscribed to at most a single monitor instance.
|
|
|
|
To stop streaming, the `stop` command is used.
|
|
|
|
|
|
|
|
### stop
|
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
The stop command is used to stop a monitor.
|
2014-02-07 16:41:03 -08:00
|
|
|
The request looks like:
|
|
|
|
|
|
|
|
```
|
|
|
|
{"Stop": 50}
|
|
|
|
```
|
|
|
|
|
2014-02-18 15:30:07 -08:00
|
|
|
This unsubscribes the client from the monitor with `Seq` value of 50.
|
2014-02-07 16:41:03 -08:00
|
|
|
|
|
|
|
There is no special response body.
|
|
|
|
|
|
|
|
### leave
|
|
|
|
|
|
|
|
The leave command is used trigger a graceful leave and shutdown.
|
|
|
|
There is no request body, or special response body.
|
|
|
|
|
2014-02-23 17:09:59 -08:00
|
|
|
### stats
|
|
|
|
|
2014-06-19 13:53:43 -05:00
|
|
|
The stats command is used to provide operator information for debugging.
|
2014-02-23 17:09:59 -08:00
|
|
|
There is no request body, the response body looks like:
|
|
|
|
|
|
|
|
```
|
|
|
|
{
|
|
|
|
"agent": {
|
|
|
|
"check_monitors": 0,
|
|
|
|
...
|
|
|
|
},
|
|
|
|
"consul: {
|
|
|
|
"server": "true",
|
|
|
|
...
|
|
|
|
},
|
|
|
|
...
|
|
|
|
}
|
|
|
|
```
|
2014-06-11 10:54:36 -07:00
|
|
|
|
|
|
|
### reload
|
|
|
|
|
|
|
|
The reload command is used trigger a reload of configurations.
|
|
|
|
There is no request body, or special response body.
|
|
|
|
|