/debops-playbooks

Ansible playbooks used by DebOps project

Primary LanguagePythonGNU General Public License v3.0GPL-3.0

debops_logo DebOps playbooks

CII Best Practices

This repository contains all the playbooks used by DebOps.

Here are a few services that are available

Fully loaded ready to go applications

GitLab GitLabCI Etherpad DokuWiki ownCloud phpIPAM Mailman

Databases

PostgreSQL MariaDB MySQL Redis Memcached Elasticsearch

Programming languages

Ruby Golang Java NodeJS PHP

Web application deployment

nginx RubyOnRails

Service monitoring and logging

LibreNMS monit rsyslog

Networking

dnsmasq DHCP Radvd ferm postfix SMS SSH NFS Samba

Virtualization

LXC Docker OpenVZ KVM

Backup and encryption

Safekeep BoxBackup encFS SKS Monkeysphere

Security

PKI dhparam slapd cryptsetup EncFS

Overview of how playbooks work within DebOps

There's a :file:`common.yml` playbook which gets ran on every host except localhost. This includes standard services like sshd and ferm. The full list can be found here.

Additional plays are then ran based on what groups the host is in. For example if you wanted to setup a Gitlab instance you would add a host to the [debops_gitlab] group in your inventory.

That carries over for things like postgresql, ruby or any service for the most part. You can also install roles as dependencies rather than use inventory groups.

The dependency approach makes sense in a lot of places, especially for setting ports through ferm or perhaps installing a database for a role that demands that database.

You can view all of the services and plays here.

View a dependency graph

Dependency graph

Status page

If you want to keep tabs on each role's status then check out our status page.