Skip to content

Latest commit

 

History

History
46 lines (25 loc) · 2.95 KB

README.md

File metadata and controls

46 lines (25 loc) · 2.95 KB

This post covers the steps I took to configure and deploy a Drupal website using Ansible. This will also be my first time using Drupal and one of my first projects I intend to put fully into production.

My main goal going forward with any homelab project is to be able to easily re-create and re-deploy any applications. Since I don't yet have a separate development lab where I can test projects without completely destroying my production environment (which is an upcoming project). I need a way to ensure that anything that makes it to production is as reproducible as possible.

Development Environment:

My current development setup consists of an older MacBook Air for code development, with a Github repository for version-control of the code.

Testing happens on my proxmox server where I will spin up a new VM, then create a snapshot and backup file of the base running state before I have run any test code. This allows me to easily roll-back code changes to a clean state. By using Ansible, I can have the same deployment steps run automatically to test configuration changes. When I'm done with the project, the "dev" VM is deleted and a new "production" VM is created.

Inspiration:

A lot of my code for this project comes from Jeff Geerling's book Ansible for DevOps which gives one of the best written walk through of Ansible from a beginner's prospective. You can purchase a copy of his eBook here if you want to follow along, https://www.ansiblefordevops.com/ (I recommend the LeanPub edition as he provides lifetime updates and revisions)(I have no affiliation, just giving credit where due).

Steps:

  1. Create Ubuntu Server VM in Proxmox.

  2. After install remove Virtual CD Drive and reboot

  3. Create Base level snapshot pre-app install.

  4. Add IP address to [PRODUCTION] inventory file

  5. Run ansible command from macbook to start install. ''' ansible-playbook playbook.yml -i inventory --limit PRODUCTION --ask-become '''

My first run failed for "FAILED! => {"changed": false, "msg": "Failed to update apt cache: E:The repository 'file:/cdrom jammy Release' no longer has a Release file., W:Updating from such a repository can't be done securely, and is therefore disabled by default., W:See apt-secure(8) manpage for repository creation and user configuration details., W:http://ppa.launchpad.net/ondrej/php/ubuntu/dists/jammy/InRelease: Key is stored in legacy trusted.gpg keyring (/etc/apt/trusted.gpg), see the DEPRECATION section in apt-key(8) for details."}"

This is due to an extra line in /etc/apt/sources. The fix was to comment out the extra line.

  1. Get install script from Cloudflare zero-trust tunnel. SSH into VM and run.

I'll work on creating a post on setting up Cloudflare tunnels at a later date.

Once the tunnel is live, the site should now be up and running and you should see a default post page.

Default Drupal Post

  1. Login and create a new user account with admin rights. Change the default password for the default admin account and disable it. ​