Run ansible playbooks during deployment
This repository has been archived on 2020-05-08. You can view files and clone it, but cannot push or open issues or pull requests.
Go to file
2020-03-20 01:02:52 +01:00
dependencies Add common functions 2020-03-19 23:45:06 +01:00
functions Use more logging 2020-03-20 01:02:52 +01:00
LICENSE Another push to get this out the door 2020-03-19 01:43:41 +01:00
plugin.toml Bootstrap this plugin 2020-03-19 01:13:54 +01:00
post-deploy Get roles path working 2020-03-20 00:11:35 +01:00
post-extract Don't run empty outputs 2020-03-19 23:47:05 +01:00
pre-deploy Get roles path working 2020-03-20 00:11:35 +01:00
README.md Improved README and more explicity ansible commands 2020-03-19 23:54:34 +01:00

dokku-ansible-playbook

Run ansible playbooks during deployment.

This plugin can be useful when you need to provision your server before or after a deployment of your application (or on any hook, just raise an issue and let's add it) and you prefer to use Ansible instead of Bash. For example, you make use of the ansible-dokku roles.

Requirements

  • dokku 0.19.13+
  • Debian based system (uses apt package manager for installing dependencies)

Installation

$ dokku plugin:install https://github.com/decentral1se/dokku-ansible-playbook.git
$ dokku plugin:install-dependencies

Usage

All files must be placed within the ansible folder of your git repository.

  • requirements.yml: what role dependencies to download before running your plays.
  • pre-deploy.yml: play run before a deployment
  • post-deploy.yml: play run after a deployment

Notes:

  • Everything is copied into $DOKKU_LIB_ROOT/data/ansible/$APP on the post-extract hook.
  • Dokku will make sure that your Ansible plays are run on the right hook against the Dokku server localhost.
  • The ansible-galaxy install command is run with --force to ensure a clean slate on each hook execution.

Example

ansible/requirements.yml

---
- src: dokku_bot.ansible_dokku
  version: v2020.3.15

ansible/pre-deploy.yml

---
- hosts: all
  tasks:
    - name: Create foobar group
      group:
        name: foobar
        system: true
        state: present