|
|
||
|---|---|---|
| .. | ||
| bootstrap.json | ||
| consul.sh | ||
| README.md | ||
| server.json | ||
| servers.yml | ||
| Vagrantfile | ||
Running a Consul Cluster in Vagrant
These files were created to allow users to use Vagrant (http://www.vagrantup.com) quickly and relatively easily spin up a Consul (http://www.consul.io) cluster. The configuration was tested using Vagrant 1.7.2, VMware Fusion 6.0.5, and the Vagrant VMware plugin.
Contents
-
boostrap.json: This Consul configuration file contains configuration directives to bootstrap the Consul cluster. This file is copied to
/etc/consul.d/bootstrap/config.jsonby the Vagrant file provisioner. You should not need to edit this file. -
consul.sh: This shell script is executed by the Vagrant shell provisioner to provision the Ubuntu base box with the Consul binary. This shell script was written for an Ubuntu system; edits will likely be necessary for use with a different Linux distribution.
-
README.md: This file you're currently reading.
-
server.json: This Consul configuration file contains configuration directives to run the Consul agent as a server. This file is copied to
/etc/consul.d/server/config.jsonby the Vagrant file provisioner. The IP addresses specified in this file must match the IP address specified inservers.yml. -
servers.yml: This YAML file contains a list of VM definitions. It is referenced by
Vagrantfilewhen Vagrant instantiates the VMs. You will need to edit this file to provide appropriate IP addresses and other VM configuration data (see "Instructions" below). If you edit the IP addresses in this file, you must also editserver.jsonto supply matching IP addresses there as well. -
Vagrantfile: This file is used by Vagrant to spin up the virtual machines. This file is fairly extensively commented to help explain what's happening. You should be able to use this file unchanged; all the VM configuration options are stored outside this file.
Instructions
These instructions assume you've already installed VMware Fusion, Vagrant, and the Vagrant VMware plugin. Please refer to the documentation for those products for more information on installation or configuration.
-
Use
vagrant box addto install an Ubuntu 14.04 x64 box for the vmware_fusion provider. I have a base box you can use for this purpose; to use my Ubuntu 14.04 x64 base box, add the box withvagrant box add slowe/ubuntu-trusty-x64. -
Place the files from the
consuldirectory of this GitHub repository into a directory on your local system. You can clone the entire "learning-tools" repository (usinggit clone) or just download the specific files from the theconsulfolder. -
Edit the
servers.ymlfile to provide the specific details on the VMs that Vagrant should create. TheVagrantfileexpects five values for each VM:name(the user-friendly name of the VM, which will also be used as the hostname for the guest OS inside the VM);box(the name of an Ubuntu 14.04 base box);ram(the amount of memory to be assigned to the VM);vcpu(the number of vCPUs that should be assigned to the VM); andpriv_ip(an IP address to be statically assigned to the VM and is used for Consul cluster communications). -
Once you have edited
servers.yml(andserver.json, if you changed the IP addresses inservers.yml), usevagrant upto bring up the 3 systems that will serve as your Consul cluster. -
Once Vagrant has finished bringing up the VMs, simply use
vagrant ssh consul-01(whereconsul-01is the value assigned to the first VM fromservers.yml) to connect to the VM. No password should be required; it should use the default (insecure) SSH key. Once you are logged into the first VM, bootstrap the Consul cluster with this command:consul agent -config-dir /etc/consul.d/bootstrap -advertise 192.168.1.101 -client 0.0.0.0If you changed the IP address assigned to the first VM in
servers.yml, then substitute the appropriate address for the-advertiseparameter in the above command. -
In a separate terminal window, connect to the second VM using
vagrant ssh consul-02. (If you changed the name inservers.yml, specify the changed name here.) Launch the second member of the Consul cluster with this command:consul agent -config-dir /etc/consul.d/server -advertise 192.168.1.102 -client 0.0.0.0Change
192.168.1.102in the command above if you changed the IP address specified for the second VM inservers.yml. -
In yet another terminal window, connect to the third VM using
vagrant ssh consul-03(or the name provided inservers.ymlfor the third VM). Launch the third member of the Consul cluster with this command (change the IP address to match what is provided inservers.yml):consul agent -config-dir /etc/consul.d/server -advertise 192.168.1.103 -client 0.0.0.0 -
At this point, return to the first terminal window (where you are connected to the initial Consul instance launched to bootstrap the cluster) and press Ctrl+C to kill that instance. Launch it again as a "normal" Consul instance with this command:
consul agent -config-dir /etc/consul.d/server -advertise 192.168.1.101 -client 0.0.0.0 -rejoinConsul should re-join the other two nodes in the cluster.
At this point, you have a functional Consul cluster running under Vagrant. If you are using VMware Fusion, you should have IP connectivity to the VMs, and can use the OS X consul binary to connect to the cluster and test it. For example, this command would work to demonstrate that Consul is working (you would need to change the IP address provided after -rpc-addr):
consul members -rpc-addr=192.168.1.101:8400
Enjoy!