You have recently joined a new company as their lead DevOps Engineer. They would like you to lead the setup of their new blogging platform using Ghost.
Previously one of their engineers setup the server to host some old insecure Wordpress blog, without any version control, configuration management, backups, monitoring etc. This has been a major headache ever since, so now they brought in the big guns (You) to do a proper job.
The decision has been made to start from scratch with a freshly provisioned Ubuntu VM to host the Ghost application. The VM instance is to be provisioned and operate on AWS free tier which should be sufficient for development purposes for now. It is crucial that you make it as frictionless as possible for the developers to get started with the instance and any future operations.
Following the guides on Ghost’s website, you should setup a basic Ghost application running on an EC2 instance. Don’t worry about customizing it just yet, getting it to display the default page is fine.
While the developers are writing code, you are tasked with making it easy and safe for them to continuously deploy their changes in the future. Since you know that the better job you do at automating the whole setup, the more free time you’ll have to do more fun stuff, you rely on your trusted tools (git, Terraform, Docker etc.) to make life easier for yourself and the developers.
- Create a new user with home directory + SSH identity
- Install Ghost application + dependencies
- Setup the firewall to only allow SSH and Ghost traffic through
- Setup a cron-job that:
- dumps the database
- saves a snapshot of the production site under
/backup
directory - mails you a summary every night
- Create a way for developers to push new changes to Ghost in an easy and repeatable way
- Git repo with Terraform manifest(s) (or any other automation system code) to provision and configure the VM instance.
- Very clear instructions for the developers on how they can provision this new infrastructure from scratch to deploy their own Ghost instance, push changes and view them.
- A paragraph reflecting on the solution and pointing out what can be improved given more time going forward.