NEW Apache Aurora Mesos Preliminary Support for Docker Containers
With the research we’ve been doing into deploying our services using Docker containers on
Apache Mesos, we’re always on the lookout for new developments in the Mesos/containerisation
space. Recently, the Apache Aurora Mesos framework added preliminary support for Docker containers in their 0.7.0
release, so we had to try it out!
Why Apache Aurora?
If you’ve tried to deploy Docker on Mesos before, you’ve probably heard of Mesosphere’s Marathon framework. Why jump to Aurora if it already works? Aurora offers a few more features over Marathon, including an advanced DSL for scripting your tasks and a proven track record in powering Twitter.
Apache Aurora Architecture
Aurora is a Mesos framework, so if you’re unfamiliar with the general architecture of Mesos, I’d recommend you skim read one of our previous Running Docker containers on Apache Mesos post. However Aurora is a little more complicated than other frameworks - when launching a container it copies its own executor into the container’s sandbox, which communicates with the observer, which reports task status back to the scheduler.
This has the unfortunate downside of requiring your container to contain python and Mesos native libraries, in return for finer grained process control through Aurora’s DSL.
Getting up and Running with Vagrant
Getting a demonstration cluster up and running should be as simple as installing Virtualbox and Vagrant, then running the following commands:
git clone https://github.com/apache/aurora
cd aurora && vagrant up
This could take around 15 minutes, so be patient!
In the meantime let’s explore aurora’s job configuration. Usually called [job name].aurora, they’re syntactically valid
Python and must contain 3 objects: Job, Task and Process, and a list of Job objects to run called “jobs.” If you’re
using Docker, it should also specify the container image to use. A full example is detailed below, a container that runs
2 processes. Feel free to check out the code from GitHub
archive-aurora-web-containers
repository.
In order to deploy the container on to your aurora cluster, enter your virtual machine running aurora using vagrant ssh. Create your job file, and run it using the client like so:
$ aurora job create devcluster/web-server/devel/nginx nginx.aurora
# Output:
INFO] Creating job nginx
INFO] Checking status of devcluster/web-server/devel/nginx
Job create succeeded: job url=http://192.168.33.7:8081/scheduler/web-server/devel/nginx
Visit the scheduler to see the status of the job. Beware that if you did not pre-pull the image and it takes too long to download, the scheduler will kill the container and try again. Don’t worry - it should come up eventually!
DevOps Engineer Next Steps
Explore the official Aurora documentation and deploy your own containers across Mesos on Aurora!