This repository contains a Rails 8 app with Terraform files for deploying the app on Google Cloud. The app uses Kamal v2 for deployment.
Why use Rails 8 with Terraform, Google Cloud, and Kamal v2?
- Infrastructure as Code: Terraform allows you to define your infrastructure in code, making it easier to manage and scale. By using Terraform, you don't have to configure anything in the Google Cloud Console manually.
- Consistent Deployments: With Terraform, you can ensure that your infrastructure is consistent across all environments. This helps in reducing errors and ensuring that your app runs smoothly.
- Scripts to stand-up and tear-down the infrastructure: The Terraform files in this repository include scripts to create and destroy the infrastructure. This makes it easy to spin up a new environment for testing and tear it down when you're done. Don't pay for resources you're not using!
- Kamal v2: Kamal v2 is a lightweight deployment tool that makes it easy to deploy Rails apps to Google Cloud. It handles the deployment process for you, so you don't have to worry about setting up Kubernetes clusters or managing containers.
- Rails 8: Rails 8 is the latest version of the popular Ruby on Rails framework. It comes with many new features and improvements that make it easier to build web applications.
- Google Cloud: Google Cloud is a powerful cloud platform that offers a wide range of services for building and deploying applications. By using Google Cloud, you can take advantage of its scalability, reliability, and security features.
- Google Cloud SDK with a gcloud account.
- Terraform.
- Some domain name where you can add an A record to point to your server's IP address.
- Docker
- Ruby 3.3.4
- Clone this repository.
- Install the required gems:
bundle install
- Edit the
terraform-gcloud/variables.tf
file with your project details. - Edit the
config/deploy.yml
file with your domain name (currently set tokamal.shakacode.com
)
-
To create the infrastructure on Google Cloud, run the following command:
./terraform-gcloud/bin/stand-up
-
Notice the outputted IP address. Add an A record to your domain name pointing to this IP address.
-
Deploy the Rails app using Kamal v2:
bundle exec kamal setup
Notice an error message. This will happen because the schema needs to created the first time.
-
Deploy the Rails app using Kamal v2:
bundle exec kamal deploy
-
Visit your domain name in the browser to see your Rails app running on Google Cloud!
- To destroy the infrastructure on Google Cloud, run the following command:
./terraform-gcloud/bin/tear-down
That's it!