This document describes how to create a private PaaS service using tsuru and docker.
This document assumes that tsuru is being installed on a Ubuntu 12.04 LTS 64-bit machine.
Before install, let's install curl and python-software-properties, that are used to install extra repositories.
sudo apt-get update
sudo apt-get install curl python-software-properties -qqy
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv-keys 36A1D7869245C8950F966E92D8576A8BA88D21E9
echo "deb http://get.docker.io/ubuntu docker main" | sudo tee /etc/apt/sources.list.d/docker.list
sudo apt-add-repository ppa:tsuru/lvm2 -y
sudo apt-add-repository ppa:tsuru/ppa -y
sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 7F0CEB10
echo "deb http://downloads-distro.mongodb.org/repo/ubuntu-upstart dist 10gen" | sudo tee /etc/apt/sources.list.d/mongodb.list
sudo apt-get update
sudo apt-get install mongodb-10gen -qqy
sudo apt-get install beanstalkd -qqy
cat > /tmp/default-beanstalkd <<EOF
BEANSTALKD_LISTEN_ADDR=127.0.0.1
BEANSTALKD_LISTEN_PORT=11300
DAEMON_OPTS="-l \$BEANSTALKD_LISTEN_ADDR -p \$BEANSTALKD_LISTEN_PORT -b /var/lib/beanstalkd"
START=yes
EOF
sudo mv /tmp/default-beanstalkd /etc/default/beanstalkd
sudo service beanstalkd start
sudo apt-get install redis-server -qqy
sudo apt-get install node-hipache -qqy
sudo start hipache
sudo apt-get install lxc-docker -qqy
echo export DOCKER_OPTS=\"-H 127.0.0.1:4243\" | sudo tee -a /etc/default/docker
echo export DOCKER_HOST=127.0.0.1:4243 >> ~/.bashrc
sudo stop docker
sudo start docker
sudo apt-get install gandalf-server -qqy
hook_dir=/home/git/bare-template/hooks
sudo mkdir -p $hook_dir
sudo curl https://raw.githubusercontent.com/tsuru/tsuru/master/misc/git-hooks/post-receive -o ${hook_dir}/post-receive
sudo chmod +x ${hook_dir}/post-receive
sudo chown -R git:git /home/git/bare-template
# make sure you write the public IP of the machine in the "host" parameter
# in the /etc/gandalf.conf file
sudo start gandalf-server
sudo start git-daemon
sudo apt-get install tsuru-server -qqy
sudo curl http://script.cloud.tsuru.io/conf/tsuru-docker-single.conf -o /etc/tsuru/tsuru.conf
# make sure you replace all occurrences of {{{HOST_IP}}} with the machine's
# public IP in the /etc/tsuru/tsuru.conf file
sudo sed -i -e 's/=no/=yes/' /etc/default/tsuru-server
sudo start tsuru-ssh-agent
sudo start tsuru-server-api
sudo start tsuru-server-collector
curl https://raw.githubusercontent.com/tsuru/tsuru/master/misc/platforms-setup.js | mongo tsuru
And then install your preferred platform from basebuilder. For example, Python:
docker build --no-cache -t tsuru/python https://raw.githubusercontent.com/flaviamissi/basebuilder/master/python/Dockerfile
Replace Python with the desired platform (check basebuilder for a list of available platforms).
Congratulations! At this point you should have a working tsuru server running on your machine, follow the :doc:`tsuru client usage guide </apps/client/usage>` to start build your apps.
Here you will find a complete step-by-step example of how to install a mysql service with tsuru: :doc:`Install and configure a MySQL service </services/mysql-example>`.
You can integrate any DNS server with tsuru. :doc:`Here you can find an example of using bind as a DNS forwarder </misc/dns-forwarders>`, integrated with tsuru.