Docker + Capistrano = Warp Speed
Needless to say that Docker is pretty awesome. This blog itself is now powered by Docker + Capistrano and I can deploy a new post simply by doing bundle exec cap deploy. What’s more with Docker, I can move to any hosting provider and setup everything in 10 minutes. Also, gone are the days when I had to fiddle to Chef/Puppet scripts to try and setup servers only to find a new Ruby/JDK/Node.js version is out so I need to modify those scripts again. With Docker all you need to install on a new server is probably -
- Git and
- Docker
And maybe setup a user with whom you will deploy the application.
If your mind is not blown already, allow me to demonstrate with an application. Let’s say we have a web application, maybe it is a Rails application, all we need is a Dockerfile (for example) -
And a capistrano deploy script -
For the Dockerfile, the base image (phusion-passenger-docker) does a lot of groundwork for us so all we need to is setup the code and some configuration. You can test the image build and container locally to your heart’s content before deploying. The capistrano script in the end Git clones our code, builds the docker image for our code and runs a container based on the image. All with one command -
Once your deployment finishes, you have a working application and all you installed on your server was Docker and Git. That is pretty awesome IMHO! Code for this sample application is available on Github.
##Database Setup
Some of you might say, I pulled a fast one and did not talk about the database. I think there are two options for that -
- Run the database itself as a container. In this case you need to install docker-compose for the two containers to talk to each other.
- Run the database on the host / separate machine on the network. I like this option personally since unlike the application code, the database is a pretty static and stable piece of software. In this case you need to install PostgreSQL as usual and configure it so that it allows access from the Docker container. This is pretty standard for any application.
Database on the Docker host
Simple applications / test setup usually has the application server and the database server running on the same machine. To enable a Docker container to connect to the PostgreSQL instance on the Docker host you will need to change two files.
- sudo vim /etc/postgresql/9.3/main/postgresql.conf Add the line - listen_addresses = ‘localhost, 172.17.42.1’
- sudo vim /etc/postgresql/9.3/main/pg_hba.conf Add the line - host all all 172.17.0.0/24 md5
Then restart PostgreSQL. These two changes allow connections to PostgreSQL from the Docker container. Basically we allow the Docker’s internal network’s bridge and IP to connect to PostgreSQL. If your container’s bridge and IP differ, please update the two files. You can find these two by running ifconfig inside the container and on the host machine.