Ansible playbooks and Vagrantfile for the Atlas of Economic Complexity, and the aid explorer.
Important! Use ansible 2.5, but no later.
To easily install a virtualized dev environment from scratch:
- Install pre-requirements (5 min):
- Virtualbox: https://www.virtualbox.org/wiki/Downloads . Virtualbox lets you run virtual computers on top of your actual one that you can run a separate operating system on, allowing you to install the atlas in its own contained environment instead of polluting your computer.
- Vagrant: http://www.vagrantup.com/downloads.html . Vagrant lets you create, automate, tear down and manage virtualized environments (that run on Virtualbox).
- Ansible: Install ansible globally with
sudo pip install ansible
(or use easy_install instead of pip). Ansible automates installation of software packages and creation of configuration files, so you don’t have to manually install all the little components that are required to get the atlas to work. - Double check that the installs worked by running
ansible
andvagrant
in the command line, and by running virtualbox.
- Clone the code (30s):
- Run
git clone https://github.com/cid-harvard/atlas-playbooks.git && cd atlas-playbooks
- Run
git submodule init && git submodule update
to get all the submodules.
- Make sure you have the data (30s - 5min):
- Put a gzip-compressed atlas db dump into the vagrant_shared directory and name it atlas_dump.sql.gz. Ask Mali for it. It should have a shasum of 903e69a3ff70ad33f434abd9cf7726fd45fa5fdd.
- Begin installing (30min)
- Do
vagrant plugin install vagrant-bindfs
. - Do
vagrant up
. Sit back and wait until all the stuff downloads. It'll download a 350mb VM image, around that much more for all the required python and ubuntu packages. The “importing atlas DB” part takes the longest.
- Test it out!
- Run
vagrant ssh
to get in, thencd /srv/atlas/
andsource env/bin/activate
to get into the virtualenv. Then go indjango_files
and run./manage.py runserver 0.0.0.0:8001
. The 0.0.0.0 is important to get django to answer requests that come from outside the VM. - Go to http://127.0.0.1:8000/ with your browser on the outside.
- Run “vagrant up” to start the box, "vagrant ssh" to get into the box, "vagrant suspend" to save the state of the box (akin to “hibernate”) and “vagrant halt” to stop it completely.
- There are two shared directories with the VM. Any change made within the VM
reflects to the outside of the VM, and vice versa.
vagrant_shared/
: For moving over large SQL dumps etc.atlas/
: Contains the main source for the site, a checkout of the atlas-economic-complexity repo. You can write / edit code on this. Inside the box, this maps to the /srv/atlas directory.
- The usual development process involves working with your editor on the “atlas” directory outside the VM and have those changes reflected automatically to the inside. You ssh in to stop / start the server processes. If you’re going to make configuration changes, it might make sense to add them to the ansible playbooks instead of manually doing them if you want to preserve those changes and have them reflected across all installations.
- Run “git pull” to get the latest version of the playbooks from git, and then "vagrant provision” to get vagrant to do all the new installation / configuration needed.
- Run "vagrant destroy" and then “vagrant up” to get a fresh reinstallation.
- Run "vagrant help" for more info on how to stop, start, reload, destroy the virtual box.
- An ansible.cfg is already set up so you can do
ansible default -m ping
oransible-playbook playbook.yml
(which is whatvagrant provision
does) - If you want to make ansible do more stuff, check out the ansible module index: http://docs.ansible.com/modules_by_category.html
- There are also port forwards for the services running inside the VM.
- 8000: main HTTP server
- 3307: mysql
- 6379: redis
- 9200: elasticsearch
Run ansible-playbook -i prod/inventory --ask-vault-pass deploy.yml
For beta run ansible-playbook -i beta/inventory playbook.yml --ask-vault-pass
You'll be asked for a Vault password, which Mali has and can add to your Keychain.