fcollova / ansible-docker-machine-swarm-cluster

A ansible workflow for creating a swarm cluster with docker machine and provision the cluster further on with ansible

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Docker Machine Swarm cluster with Ansible

This set of ansible playbooks creates a docker swarm cluster with docker-machine and collects afterwards the information for all machines and put them together into a in memory playbook for further provisioning with ansible.

The cluster creation depends on this article.

How to use it

The easiest way is to vagrant up and use the the setup_machines.yml and infra.yml playbooks afterwards. If you have real machines adjust the /ansible/hosts/server_list.yml file. Everything else gets dynamically generated.

Create some vms for testing ...
$ vagrant up 

Or adjust the /ansible/hosts/server_list.yml file with ips of your servers.

First delete old machines (attention this deletes all machines on your system). There mustn't be machines with the names of the new ones.
$ ansible-playbook setup_machines.yml

Setup up the docker-machines on your server
$ ansible-playbook setup_machines.yml

Now install the consul cluster so the swarm can connect.
$ ansible-playbook infra.yml

Check if everything works.
$ eval $(docker-machine env --swarm swarm-master-1)
$ docker info

Attention

cleanup_machines.yml will remove all docker machines on your system and spin up the new ones (if anybody can tell me how to just delete the ones that are in list would be nice). TODO: when it works to clean machines from the server_list.yml put this into the setup_machines.yml

TODOs:

  • Add labels to the nodes for creating specifix containers on specific nodes
  • Make it more dynamic so other drivers except the generic drivers can be used
  • Add Jenkins
  • Add Proxy

Credits:

Viktor Farcic https://github.com/vfarcic - Using some of his roles of his playbooks and mentoring

Jacob Blain Christen https://github.com/dweomer - Article about setting up docker swarm cluster with docker machine

About

A ansible workflow for creating a swarm cluster with docker machine and provision the cluster further on with ansible


Languages

Language:Groovy 100.0%