2014-02-07 16:41:03 -08:00
---
2020-09-01 10:14:13 -05:00
layout: commands
2020-04-07 14:55:19 -04:00
page_title: 'Commands: Leave'
description: >-
The `leave` command triggers a graceful leave and shutdown of the agent. It is
used to ensure other nodes see the agent as left instead of failed. Nodes that
leave will not attempt to re-join the cluster on restarting with a snapshot.
2014-02-07 16:41:03 -08:00
---
2014-02-18 17:32:13 -08:00
# Consul Leave
2014-02-07 16:41:03 -08:00
2014-02-18 17:32:13 -08:00
Command: `consul leave`
2014-02-07 16:41:03 -08:00
2022-01-11 08:26:58 -05:00
Corresponding HTTP API Endpoint: [\[PUT\] /v1/agent/leave](/api-docs/agent#graceful-leave-and-shutdown)
2022-01-10 12:40:11 -05:00
2014-10-19 19:40:10 -04:00
The `leave` command triggers a graceful leave and shutdown of the agent.
It is used to ensure other nodes see the agent as "left" instead of
2014-02-07 16:41:03 -08:00
"failed". Nodes that leave will not attempt to re-join the cluster
on restarting with a snapshot.
2014-02-18 17:32:13 -08:00
For nodes in server mode, the node is removed from the Raft peer set
2014-04-16 00:01:12 -04:00
in a graceful manner. This is critical, as in certain situations a
non-graceful leave can affect cluster availability.
2014-02-18 17:32:13 -08:00
2020-04-07 14:55:19 -04:00
Running `consul leave` on a server explicitly will reduce the quorum size. Even if the cluster used `bootstrap_expect` to set a quorum size initially, issuing `consul leave` on a server will reconfigure the cluster to have fewer servers.
2019-01-25 21:20:48 +01:00
This means you could end up with just one server that is still able to commit writes because quorum is only 1, but those writes might be lost if that server fails before more are added.
2022-01-10 16:44:56 -05:00
The table below shows this command's [required ACLs](/api#authentication). Configuration of
2022-03-30 16:16:26 -05:00
[blocking queries](/api-docs/features/blocking) and [agent caching](/api-docs/features/caching)
2022-01-10 16:44:56 -05:00
are not supported from commands, but may be from the corresponding HTTP endpoint.
| ACL Required |
| ------------- |
| `agent:write` |
2014-02-07 16:41:03 -08:00
## Usage
2017-02-09 16:41:17 -05:00
Usage: `consul leave [options]`
2014-02-07 16:41:03 -08:00
2017-02-09 16:41:17 -05:00
#### API Options
2014-02-07 16:41:03 -08:00
2020-04-07 14:55:19 -04:00
@include 'http_api_options_client.mdx'