/invenio-vagrant

A set of scripts for automating vagrant basebox building for Invenio, as well as provisioning and installation of Invenio on these boxes.

Primary LanguageShell

Invenio Vagrant

About

Invenio vagrant is a set of scripts for automating vagrant basebox building for Invenio, as well as provisioning and installation of Invenio on these systems.

Currently there are examples of provisioning and installing Invenio on the following boxes:

Atlantis Institute of Science Demo Site

  • lucid32: Ubuntu 10.04 32-bit (the standard Vagrant base box)
  • slc6: Scientific Linux 6.1 64-bit
  • ubuntu1204: Ubuntu 12.04 64-bit

INSPIRE

  • lucid64: Ubuntu 10.04 64-bit

Furthermore there are examples of building the baseboxes for slc6 and ubuntu1204 besides the provisioning and installation of the Atlantis demo site on these boxes.

Invenio is by default installed in a virtualenv.

Prerequisites

You must have Vagrant, Veewee and VirtualBox installed on your system.

Scripts are tested with the following versions:

Installation

  • VirtualBox: Find your package on https://www.virtualbox.org/wiki/Downloads or install via apt-get or your favourite package management tool.
  • Ruby + RubyGems: Make sure you have Ruby 1.9.x (e.g. sudo apt-get install ruby1.9.3 rubygems1.9.1 on Ubuntu 12.04).
  • vagrant: gem1.9.3 install vagrant
  • veewee: gem1.9.3 install veewee --pre
  • invenio-vagrant: git clone https://github.com/lnielsen-cern/invenio-vagrant.git
  • NFS server: sudo apt-get install nfs-kernel-server

Running: Firing up a VM with an already existing basebox

The following commands will download the standard Vagrant Ubuntu 10.04 box, run provisioning scripts and install Invenio in a Python virtualenv.

Download, start and provision VM (this will not work if you already have a basebox named base - you can check that with the command vagrant box list).

git clone https://github.com/lnielsen-cern/invenio-vagrant.git
cd invenio-vagrant/atlantis-lucid32/
vagrant up

Login to VM:

vagrant ssh

Install Invenio 1.0.1 with Atlantis Demo Site

vagrant@localhost:~$ . /vagrant/invenio.sh

Finally, activate the virtualenv and run the invenio-devserver.

vagrant@localhost:~$ . ~/envs/atlantis/bin/activate
(atlantis) vagrant@localhost:~$ serve -b 0.0.0.0
HTTP Server mode with reload mode
 * Running on http://0.0.0.0:4000/
 * Spawning worker
 * Ready

Now go to http://192.168.33.10:4000 (see atlantis-lucid32/Vagrantfile if you wonder where the IP address came from).

Running: Building a new basebox and firing it up

The following will build a new basebox (create a VM, install a fresh system on it, make all the necessary changes for a vagrant basebox) which is then provisioned and later Invenio is installed on it.

git clone https://github.com/lnielsen-cern/invenio-vagrant.git
cd invenio-vagrant/basesboxes/

Builds a new Ubuntu 12.04 base box (takes some time).

vagrant basebox build ubuntu1204

Exports the basebox to a file

vagrant basebox export ubuntu1204 ubuntu1204.box

Import the basebox in vagrant under the name ubuntu1204 (which is referenced by Vagrantfile)

vagrant box add ubuntu1204 ubuntu1204.box

Fire up the VM (first time provisioning will run, and it may take longer time)

cd invenio-vagrant/atlantis-ubuntu1204/
vagrant up

Login to new VM

vagrant ssh

Install Invenio in a virtualenv

vagrant@vm$ . /vagrant/invenio.sh

... lots of output ...

Activate Python's virtualenv

vagrant@vm$ soruce ~/envs/atlantis/bin/activate

Launch development server (listining on all interfaces)

vagrant@vm (atlantis)$ serve -b 0.0.0.0

Now go to http://192.168.33.12:4000 (note IP address changes from VM to VM - look in Vagrantfile)

Notes

By default all VMs are setup to share a folder ~/src on your host with the VM. On a VM the folder can be accssed in /home/vagrant/src. This allows you easily access your source code on the host system from your VM. If you want to change it, just find and edit the config.vm.share_folder option in the Vagrantfile.