Skip to content

AU-Biocommons/genome-annotation

Repository files navigation

Genome Annotation

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

Ansible is an automation tool for defining the target state of a host VM. Tasks to be run are specified using YAML.

  1. Tasks are the atomic changes made to a host VM.
  2. Tasks are grouped into roles.
  3. Roles can be used by playbooks to make the steps for each system easy to understand and define.

Folder Structure of the Genome Annotation Repo

The structure of this repo is as below:

  1. The playbooks folder inside the ansible folder. The playbooks folder has the below content:

    • ansible.cfg: Ansible configuration file
    • hosts: Ansible inventory file with ALL VMs, meaning prod VMs and test VMs
    • playbook-*: playbooks are lightweight and contain a list of roles to be executed for a purpose
    • For more information see README files in ansible/playbooks/README.md
  2. 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 prefix common 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.
  3. 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 file
    • Vagrantfile: Vagrant configuration file
    • playbook-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

How to Create/Modify Ansible Roles

For more information see README file in ansible/README.md

What is an Apollo VM

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:

  1. nginx
  2. tomcat
  3. postgres
  4. openjdk
  5. Apollo Web App
  6. Monitoring tools
  7. 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.

About

Australian Biocommons Genome Annotation (Apollo)

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published