LXC is a lightweight virtualization method that provides operating system-level virtualization optional to an heavy full virtual machine. It relies on the Linux kernel cgroups functionality that became available in version 2.6.24, It provides a virtual environment that has its own process and network space. This option makes the perfect option for deploying several contained Drupal dev environments independent of the distribution.Docker is a solution from dotCloud, which simplifies and improves the process of creating and managing Linux containers. Vagrant 1.1+ lxc plugin allows it to control and provision Linux Containers as an alternative to the built in (and heavy) Vagrant VirtualBox provider for Linux hosts.
Deploy and develop on Drupal with LXC, using Vagrant and/or Docker.
Takes about ~2 minutes to have a full running Drupal development box. Installing Drupal on lxc containers has never been faster and easier.
- Drupal (latest version)
- Nginx
- Php + php-fpm
- Mysql
- Phpmyadmin
- xhprof
- xdebug
- composer
Install latest Vagrant from: http://downloads.vagrantup.com/tags/v1.2.7 or later.
sudo dpkg -i vagrant_1.2.7_x86_64.deb
sudo apt-get install lxc redir git sudo
git clone https://github.com/ricardoamaro/drupal-lxc-vagrant-docker.git
cd ~/drupal-lxc-vagrant-docker
vagrant plugin install vagrant-lxc
vagrant up --provider=lxc
sudo lxc-ls --fancy
# redirect port 80 to the host
sudo redir --lport=80 --cport=80 --caddr={container ip} &
your /etc/hosts file should have a line like this:
127.0.2.1 drupal phpmyadmin xhprof
- Access Drupal on http://drupal
- Access Phpmyadmin on http://phpmyadmin/
- Access drupal files on /var/lib/lxc/{container name}/rootfs/var/www/
- Access XHProf logs at http://xhprof
- Mysql root password: puppetdrupal
~/drupal-lxc-vagrant-docker# vagrant halt
~/drupal-lxc-vagrant-docker# vagrant up --no-provision
~/drupal-lxc-vagrant-docker# VAGRANT_LOG=debug vagrant up --provider=lxc
~/drupal-lxc-vagrant-docker# vagrant destroy
~/drupal-lxc-vagrant-docker# sudo killall redir
Docker will be used to ship our newly created appliance, deploying it to any linux server, anywhere in the world, whitin a container.
sudo apt-get -y install lxc-docker
curl get.docker.io | sudo sh -x
sudo tar -C /var/lib/lxc/{container name}/rootfs/ -c . | sudo docker import - dev/drupal
sudo docker run -i -t -p :80 dev/drupal /bin/bash
An already cooked Docker image has been commited to https://index.docker.io, and can be pulled using:
sudo docker pull ricardoamaro/drupal
*There is also a project to build a simple lamp image with Drupal, using Dockerfile: https://github.com/ricardoamaro/docker-drupal
*You can find more images using the Docker Index.
- Since this a pure devops work towards actual running production environments, one of the primary targets is to deploy to the cloud using several hosts to achieve a real hosting structure.
- Using the shipping container concept of docker it would be great to have the container fill up the several jobs that Drupal work with, like:
- Separated mysql/mariadb,
- Redis,
- Solr,
- Varnish,
- Load balancers...
- Upstart on Docker is broken due to this issue, and that's one of the reasons the image is puppetized using vagrant.
- Warning: This is still in development and ports shouldn't be open to the outside world.
- The vagrant uses the vagrant pub ssh key, but you can remove that while using
lxc-attach -n {container name}
Feel free to fork and contribute to this code. :)
- Fork the repo
- Create your feature branch (
git checkout -b my-new-feature
) - Commit your changes (
git commit -am 'Added some feature'
) - Push to the branch (
git push origin my-new-feature
) - Create new Pull Request
Created and maintained by Ricardo Amaro ([email protected])
GPLv2+