From 626d5264a8fda09350fece2e5fe10298e42b2cd4 Mon Sep 17 00:00:00 2001 From: Brian Shumate Date: Thu, 13 Apr 2017 13:03:26 -0400 Subject: [PATCH 1/2] Docs: update bootstrapping and config, fixes #2867 - Add various join options to bootstrapping guide - Add note about Atlas deprecation to bootstrapping guide - Add notes about -retry-join and retry_join to -join option - Add notes about -retry-join and retry_join to start_join option --- .../source/docs/agent/options.html.markdown | 13 ++++-- .../docs/guides/bootstrapping.html.markdown | 41 +++++++------------ 2 files changed, 24 insertions(+), 30 deletions(-) diff --git a/website/source/docs/agent/options.html.markdown b/website/source/docs/agent/options.html.markdown index add252a391..757876f0ed 100644 --- a/website/source/docs/agent/options.html.markdown +++ b/website/source/docs/agent/options.html.markdown @@ -59,8 +59,8 @@ The options below are all specified on the command-line. address when being accessed from a remote datacenter if the remote datacenter is configured with `translate_wan_addrs`. -~> **Notice:** The hosted version of Consul Enterprise will be deprecated on - March 7th, 2017. For details, see https://atlas.hashicorp.com/help/consul/alternatives +~> **Notice:** The hosted version of Consul Enterprise was deprecated on + March 7th, 2017. For details, see https://atlas.hashicorp.com/help/consul/alternatives. * `-atlas` - This flag enables [Atlas](https://atlas.hashicorp.com) integration. @@ -193,6 +193,10 @@ will exit with an error at startup. specified multiple times to specify multiple agents to join. If Consul is unable to join with any of the specified addresses, agent startup will fail. By default, the agent won't join any nodes when it starts up. + Note that using + `retry_join` could be more appropriate to help + mitigate node startup race conditions when automating a Consul cluster + deployment.\ * `-retry-join` - Similar to [`-join`](#_join) but allows retrying a join if the first @@ -918,7 +922,10 @@ Consul will not enable TLS for the HTTP API unless the `https` port has been ass quorum, and Ctrl-C on a client will gracefully leave). * `start_join` An array of strings specifying addresses - of nodes to [`-join`](#_join) upon startup. + of nodes to [`-join`](#_join) upon startup. Note that using + `retry_join` could be more appropriate to help + mitigate node startup race conditions when automating a Consul cluster + deployment. * `start_join_wan` An array of strings specifying addresses of WAN nodes to [`-join-wan`](#_join_wan) upon startup. diff --git a/website/source/docs/guides/bootstrapping.html.markdown b/website/source/docs/guides/bootstrapping.html.markdown index 9fc18397cc..f2ffcb4289 100644 --- a/website/source/docs/guides/bootstrapping.html.markdown +++ b/website/source/docs/guides/bootstrapping.html.markdown @@ -3,7 +3,7 @@ layout: "docs" page_title: "Bootstrapping" sidebar_current: "docs-guides-bootstrapping" description: |- - An agent can run in both client and server mode. Server nodes are responsible for running the consensus protocol and storing the cluster state. Before a Consul cluster can begin to service requests, a server node must be elected leader. Thus, the first nodes that are started are generally the server nodes. Bootstrapping is the process of joining these server nodes into a cluster. + An agent can run in both client and server mode. Server nodes are responsible for running the consensus protocol and storing the cluster state. Before a Consul cluster can begin to service requests, a server node must be elected leader. Thus, the first nodes that are started are generally the server nodes. Bootstrapping is the process of joining these server nodes into a cluster. --- # Bootstrapping a Datacenter @@ -38,37 +38,24 @@ providing the `-bootstrap-expect 3` flag. Once the nodes are started, you should This indicates that the nodes are expecting 2 peers but none are known yet. To prevent a split-brain scenario, the servers will not elect themselves leader. -## Creating a cluster +## Creating the cluster -To trigger leader election, we must join these machines together and create a cluster. There are two options for joining; you can use [Atlas by HashiCorp](https://atlas.hashicorp.com?utm_source=oss&utm_medium=guide-bootstrapping&utm_campaign=consul) to auto-join or you can access the machine and manually run the join. +To trigger leader election, we must join these machines together and create a cluster. There are multiple options for joining the machines: -For auto-join using Atlas, you must set three configurations — the name of your Atlas infrastructure with the [`-atlas` flag](/docs/agent/options.html#_atlas), your Atlas token with the [`-atlas-token` CLI flag](/docs/agent/options.html#_atlas_token), and the [`-atlas-join` flag](/docs/agent/options.html#_atlas_join). Below is an example configuration: +- Manually specified list of machines with + [-join](/docs/agent/options.html#_join) and + [start_join](https://www.consul.io/docs/agent/options.html#start_join) + options +- Manually specified list of machines with [-retry-join](https://www.consul.io/docs/agent/options.html#_retry_join) option +- Automatic AWS EC2 instance joining with the [-retry-join-ec2-*](https://www.consul.io/docs/agent/options.html#_retry_join_ec2_tag_key) options +- Automatic GCE instance joining with the [-retry-join-gce-*](https://www.consul.io/docs/agent/options.html#_retry_join_gce_tag_value) options -```text -$ consul agent -server -data-dir="/tmp/consul" -bootstrap-expect 3 \ - -atlas=ATLAS_USERNAME/infrastructure \ - -atlas-join \ - -atlas-token="YOUR_ATLAS_TOKEN" -``` +Choose the method which best suits your environment and specific use case. -To get an Atlas username and token, [create an account here](https://atlas.hashicorp.com/account/new?utm_source=oss&utm_medium=guide-bootstrapping&utm_campaign=consul) and replace the respective values in your Consul configuration with your credentials. +~> **Notice:** The hosted version of Consul Enterprise was deprecated on + March 7th, 2017 and the Atlas `auto-join` feature is no longer available. For details, see https://atlas.hashicorp.com/help/consul/alternatives. -To manually create a cluster, access one of the machines and run the following: - -```text -$ consul join -Successfully joined cluster by contacting 3 nodes. -``` - -Since a join operation is symmetric, it does not matter which node initiates it. Once the join is successful, one of the nodes will output something like: - -```text -[INFO] consul: adding server foo (Addr: 127.0.0.2:8300) (DC: dc1) -[INFO] consul: adding server bar (Addr: 127.0.0.1:8300) (DC: dc1) -[INFO] consul: Attempting bootstrap with nodes: [127.0.0.3:8300 127.0.0.2:8300 127.0.0.1:8300] - ... -[INFO] consul: cluster leadership acquired -``` +## Verifying the Cluster As a sanity check, the [`consul info`](/docs/commands/info.html) command is a useful tool. It can be used to verify `raft.num_peers` is now 2, From d0fdc39bf943adc5ec10f6c925c36aa602584619 Mon Sep 17 00:00:00 2001 From: Brian Shumate Date: Thu, 13 Apr 2017 15:20:02 -0400 Subject: [PATCH 2/2] Put back manual process steps --- .../docs/guides/bootstrapping.html.markdown | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/website/source/docs/guides/bootstrapping.html.markdown b/website/source/docs/guides/bootstrapping.html.markdown index f2ffcb4289..65f1edadf4 100644 --- a/website/source/docs/guides/bootstrapping.html.markdown +++ b/website/source/docs/guides/bootstrapping.html.markdown @@ -55,6 +55,25 @@ Choose the method which best suits your environment and specific use case. ~> **Notice:** The hosted version of Consul Enterprise was deprecated on March 7th, 2017 and the Atlas `auto-join` feature is no longer available. For details, see https://atlas.hashicorp.com/help/consul/alternatives. +### Manually Creating a Cluster + +To manually create a cluster, access one of the machines and run the following: + +``` +$ consul join +Successfully joined cluster by contacting 3 nodes. +``` + +Since a join operation is symmetric, it does not matter which node initiates it. Once the join is successful, one of the nodes will output something like: + +``` +[INFO] consul: adding server foo (Addr: 127.0.0.2:8300) (DC: dc1) +[INFO] consul: adding server bar (Addr: 127.0.0.1:8300) (DC: dc1) +[INFO] consul: Attempting bootstrap with nodes: [127.0.0.3:8300 127.0.0.2:8300 127.0.0.1:8300] + ... +[INFO] consul: cluster leadership acquired +``` + ## Verifying the Cluster As a sanity check, the [`consul info`](/docs/commands/info.html) command