--- layout: "docs" page_title: "Upgrading Consul" sidebar_current: "docs-upgrading-upgrading" description: |- Consul is meant to be a long-running agent on any nodes participating in a Consul cluster. These nodes consistently communicate with each other. As such, protocol level compatibility and ease of upgrades is an important thing to keep in mind when using Consul. --- # Upgrading Consul Consul is meant to be a long-running agent on any nodes participating in a Consul cluster. These nodes consistently communicate with each other. As such, protocol level compatibility and ease of upgrades is an important thing to keep in mind when using Consul. This page documents how to upgrade Consul when a new version is released. ## Standard Upgrades For upgrades we strive to ensure backwards compatibility. To support this, nodes gossip their protocol version and builds. This enables clients and servers to intelligently enable new features when available, or to gracefully fallback to a backward compatible mode of operation otherwise. For most upgrades, the process is simple. Assuming the current version of Consul is A, and version B is released. 1. On each server, install version B of Consul. 2. Shut down version A, restart with version B. 3. Once all the servers are upgraded, begin a rollout of clients following the same process. 4. Done! You are now running the latest Consul agent. You can verify this by running `consul members` to make sure all members have the latest build and highest protocol version. ## Upgrade from Version 1.0.6 to higher In version 1.0.7 and higher, when requesting a specific service (`/v1/health/:service` or `/v1/catalog/:service` endpoints), the `X-Consul-Index` returned is now the index at which that specific service was last modified. In version 1.0.6 and earlier the X-Consul-Index returned was the index at which any service was last modified. See [GH-3890](https://github.com/hashicorp/consul/issues/3890) for more details. During upgrades from 1.0.6 or lower to 1.0.7 or higher, watchers are likely to see `X-Consul-Index` for these endpoints decrease between blocking calls. Consul’s watch feature and consul-template should gracefully handle this case. Other tools relying on blocking service or health queries are also likely to work; some may require a restart. It is possible external tools could break and either stop working or continually re-request data without blocking if they have assumed indexes can never decrease or be reset and/or persist index values. Please test any blocking query integrations in a controlled environment before proceeding. ## Backward Incompatible Upgrades In some cases, a backwards incompatible update may be released. This has not been an issue yet, but to support upgrades we support setting an explicit protocol version. This disables incompatible features and enables a 2-phase upgrade. For the steps below, assume you're running version A of Consul, and then version B comes out. 1. On each node, install version B of Consul. 2. Shut down version A, and start version B with the `-protocol=PREVIOUS` flag, where "PREVIOUS" is the protocol version of version A (which can be discovered by running `consul -v` or `consul members`). 3. Once all nodes are running version B, go through every node and restart the version B agent _without_ the `-protocol` flag. 4. Done! You're now running the latest Consul agent speaking the latest protocol. You can verify this is the case by running `consul members` to make sure all members are speaking the same, latest protocol version. The key to making this work is the [protocol compatibility](/docs/compatibility.html) of Consul. The protocol version system is discussed below. ## Protocol Versions By default, Consul agents speak the latest protocol they can. However, each new version of Consul is also able to speak the previous protocol, if there were any protocol changes. You can see what protocol versions your version of Consul understands by running `consul -v`. You'll see output similar to that below: ``` $ consul -v Consul v0.7.0 Protocol 2 spoken by default, understands 2 to 3 (agent will automatically use protocol >2 when speaking to compatible agents) ``` This says the version of Consul as well as the protocol versions this agent speaks and can understand. Sometimes Consul will default to speak a lower protocol version than it understands, in order to ease compatibility with older agents. For example, Consul agents that understand version 3 claim to speak version 2, and only send version 3 messages to agents that understand version 3. This allows features to upshift automatically as agents are upgraded, and is the strategy used whenever possible. If this is not possible, then you will need to do a backward incompatible upgrade using the instructions above, and such a requirement will be clearly outlined in the notes for a given release. By specifying the `-protocol` flag on `consul agent`, you can tell the Consul agent to speak any protocol version that it can understand. This only specifies the protocol version to _speak_. Every Consul agent can always understand the entire range of protocol versions it claims to on `consul -v`. ~> **By running a previous protocol version**, some features of Consul, especially newer features, may not be available. If this is the case, Consul will typically warn you. In general, you should always upgrade your cluster so that you can run the latest protocol version.