Add skeleton structure for OpenStack CLI learning environment and environment for etcd-backed Docker Swarm cluster.
7.2 KiB
Running an etcd-Backed Docker Swarm Cluster in Vagrant
These files were created to allow users to use Vagrant (http://www.vagrantup.com) quickly and relatively easily spin up a Docker Swarm (URL) cluster backed by etcd (URL). The configuration was tested using Vagrant 1.7.2, VMware Fusion 6.0.5, and the Vagrant VMware plugin.
Contents
-
README.md: This file you're currently reading.
-
servers.yml: This YAML file contains a list of VM definitions and associated configuration data. It is referenced by
Vagrantfilewhen Vagrant instantiates the VMs. -
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.
-
user_data: This file is used by the CoreOS cloud-init process to customize the CoreOS VMs upon instantiation. This file disables etcd and fleet, and configures Docker to listen on TCP port 2375.
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.
NOT YET COMPLETE
-
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. -
Use
vagrant box addto install a CoreOS base box. TheVagrantfileassumes you are using the Stable release of CoreOS (the box namedcoreos-stable). If the box name is different, you'll need to edit theVagrantfileaccordingly. You'll need to be sure to use a version of CoreOS that comes with Docker 1.4.0 or later, as Swarm requires Docker => 1.4.0. Note that CoreOS Stable 557.2.0 comes with Docker 1.4.1. -
Place the files from the
docker-swarmdirectory 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 thedocker-swarmfolder. -
Optionally, 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). It is not required to edit this file. You can use it without any modifications if desired. -
Once you have edited
servers.yml(andserver.json, if you changed the IP addresses inservers.yml), usevagrant upto bring up the 6 systems. Three VMs will run the Consul cluster; the other 3 VMs will be running CoreOS and will make up the Docker Swarm 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, start the Consul agent with this command:sudo service consul startRepeat this process with the other two Consul nodes (
consul-02andconsul-03if you are using the default values inservers.yml). Once Consul has been started on all three nodes, verify Consul is running correctly by running this command:consul membersConsul should report three members, using the IP addresses specified in
servers.yml. If Consul does not report three members (a minimum to bootstrap the cluster) or if it reports an error, you'll need to resolve this before continuing. -
Use
vagrant ssh coreos-01to log into the first CoreOS system (coreos-01is the default name supplied inservers.yml; if you've changed the default name, modify your command appropriately). On this system, launch a Dockerized Consul client using the following command:docker run -d -p 8300:8300 -p 8301:8301 -p 8301:8301/udp -p 8302:8302 -p 8302:8302/udp -p 8400:8400 -p 8500:8500 -p 8600:8600/udp --name consul-coreos-01 -h coreos-01 progrium/consul -rejoin -advertise 192.168.1.104 -join 192.168.1.101If you've changed the IP addresses in
servers.yml, be sure to modify the command above with the correct IP addresses (-advertiseneeds to specify the IP address assigned to the first CoreOS node, and-joinneeds to provide the IP address of one of the Consul nodes). -
While still logged into the first CoreOS system, launch an instance of Registrator:
docker run -d --name reg-coreos-01 -h coreos-01 -v /var/run/docker.sock:/tmp/docker.sock progrium/registrator consul://192.168.1.104:8500The IP address in this command must correspond to the IP address assigned to the CoreOS node as specified in
servers.yml. -
While still logged into the first CoreOS system, add it as the first node to a new Docker Swarm cluster using this command:
docker run -d swarm join --addr=192.168.1.104:2375 consul://192.168.1.104:8500/swarm -
Log out of the first CoreOS system and use
vagrant sshto log into the second and third CoreOS systems, repeating steps 7, 8, and 9 on each system. Be sure to change values for the--nameand-hparameters on each system. Also be sure that the-advertiseparameter for the Consul container maps to the IP address assigned to the host CoreOS VM (as provided inservers.yml). Make sure theconsul://parameter for the Registrator container points to the CoreOS VM's IP address as provided inservers.ymlas well. -
On the first CoreOS system (the one named
coreos-01by default), run a Docker container that will serve as the manager of the Swarm cluster. Launch the Swarm manager with this command:docker run -d -p 8333:2375 swarm manage consul://192.168.1.104:8500/swarmThe IP address specified in the
consul://URL should correspond to the IP address assigned fromservers.ymlto this node. Make note of the port exposed by the-pcommand and the IP address of the node on which you're running the Swarm manager. This will be the endpoint against which you will run Docker commands against the cluster. -
Verify the operation of the Swarm cluster by running this command (from any system that has connectivity to the CoreOS system running the Swarm manager container launched in the previous step):
docker -H tcp://192.168.1.104:8333 infoDocker should return information indicating that there are 10 containers running across 3 nodes, and then provide more information about each node and the containers running on that node.
-
Launch an Nginx container somewhere on the cluster with this command:
docker -H tcp://192.168.1.104:8333 run -d --name www -p 80:80 nginx
If everything is working as expected, Docker will launch an Nginx container on one of the CoreOS nodes in the Swarm cluster, and Registrator will register the presence of the container in Consul for service discovery.
Enjoy!