Australian Biocommons Genome Annotation (Apollo). The purpose of this repo is to Automate
the installation of all required software and its dependencies in an Apollo VM
using Ansible
.
Ansible is an automation tool for defining the target state of a host VM. Tasks to be run are specified using YAML.
- Tasks are the atomic changes made to a host VM.
- Tasks are grouped into roles.
- Roles can be used by playbooks to make the steps for each system easy to understand and define.
The structure of this repo is as below:
-
The playbooks folder inside the ansible folder. The playbooks folder has the below content:
ansible.cfg
: Ansible configuration filehosts
: Ansible inventory file withALL
VMs, meaning prod VMs and test VMsplaybook-*
: playbooks arelightweight
and contain a list of roles to be executed for apurpose
- For more information see
README
files in ansible/playbooks/README.md
-
The roles folder inside the ansible folder. The roles folder has all ansible roles that can be used by playbooks placed in playbooks folder:
Roles
: Ansible Roles contain a list of tasks to be executed in the target server. The roles are named by what they do. In example: common-install-nginx is a role that will install nginx package and the prefixcommon
means it can be used by different playbooks. The name of the folder is the name of the role and each role folder has to comply with required folder structure for ansible roles. See Ansible Roles documentation for more details.
-
The local_dev folder is optional to be used for "local development" as its name suggests. This folder has the below content:
ansible.cfg
: Ansible configuration fileVagrantfile
: Vagrant configuration fileplaybook-test-roles.yml
: Ansible playbook for testing ansible roles in local Vagrant development environment- For more information see
README
files in local_dev/README.md
For more information see README
file in ansible/README.md
An Apollo VM will run an Apollo Web App software and all its dependencies on Ubuntu OS. In summary the dependencies and software installed in an Apollo VM are as below:
- nginx
- tomcat
- postgres
- openjdk
- Apollo Web App
- Monitoring tools
- Among Others
For more details refer to old manual instructions Apollo Deployment Document. Note that this document is only for reference and to give a better understanding of all that is required to have an Apollo VM up and running as currently the Ansible Playbooks will automate the software installation process.