Chapter 7. Deploying Mezzanine with Ansible

It’s time to write an Ansible playbook, one to deploy Mezzanine to a server. We’ll go through it step by step, but if you’re the type of person who starts off by reading the last page of a book to see how it ends, you can find the full playbook at the end of this chapter as Example 7-27. It’s also available on GitHub. Check out the README file before trying to run it directly.

We have tried to hew as closely as possible to the original scripts that Mezzanine author Stephen McDonald wrote.1

Listing Tasks in a Playbook

Before we dive into the guts of our playbook, let’s get a high-level view. The ansible-playbook command-line tool supports a flag called --list-tasks. This flag prints out the names of all the tasks in a playbook. Here’s how you use it:

$ ansible-playbook --list-tasks mezzanine.yml

Example 7-1 shows the output for the mezzanine.yml playbook in Example 7-27.

Example 7-1. List of tasks in Mezzanine playbook
 playbook: mezzanine.yml play #1 (web): Deploy mezzanine TAGS: [] tasks: Install apt packages TAGS: [] Create project path TAGS: [] Create a logs directory TAGS: [] Check out the repository on the host TAGS: [] Create python3 virtualenv TAGS: [] Copy requirements.txt to home directory TAGS: [] Install packages listed in requirements.txt TAGS: [] Create project locale TAGS: [] Create a DB user TAGS: [] Create the database TAGS: [] Ensure config path exists TAGS: [] Create tls certificates TAGS: [] Remove the default nginx ...

Get Ansible: Up and Running, 3rd Edition now with the O’Reilly learning platform.

O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.