Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rafaumeu/multicloud-iac-journey
🚀 Infrastructure as Code (IaC) journey exploring GCP, Azure, and AWS using Terraform. Features Compute Engine, Cloud Functions, and more.
https://github.com/rafaumeu/multicloud-iac-journey
aws azure cloud-computing cloud-infrastructure devops gcp infrastructure-as-code multicloud terraform terraform-modules
Last synced: 3 days ago
JSON representation
🚀 Infrastructure as Code (IaC) journey exploring GCP, Azure, and AWS using Terraform. Features Compute Engine, Cloud Functions, and more.
- Host: GitHub
- URL: https://github.com/rafaumeu/multicloud-iac-journey
- Owner: rafaumeu
- Created: 2025-02-07T14:04:00.000Z (14 days ago)
- Default Branch: main
- Last Pushed: 2025-02-17T09:30:48.000Z (4 days ago)
- Last Synced: 2025-02-17T10:22:41.833Z (4 days ago)
- Topics: aws, azure, cloud-computing, cloud-infrastructure, devops, gcp, infrastructure-as-code, multicloud, terraform, terraform-modules
- Language: HCL
- Size: 13.7 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# 🚀 MultiCloud IaC Journey
A modern infrastructure as code project exploring multiple cloud providers (GCP, Azure, AWS) using Terraform.
[data:image/s3,"s3://crabby-images/429a6/429a681d5afc49e452682d5d9b0da3a0b7ddab7b" alt="Terraform"](https://www.terraform.io/)
[data:image/s3,"s3://crabby-images/055e9/055e910b451b523964b1ae800fb69fe7a6c6e94b" alt="GCP"](https://cloud.google.com/)
[data:image/s3,"s3://crabby-images/e50c3/e50c3018b9b68f7332c9625b22a87bd7e62126a8" alt="Azure"](https://azure.microsoft.com/)
[data:image/s3,"s3://crabby-images/8fe25/8fe252f76dc2a000f81c31eb23c03acd6799638b" alt="License"](LICENSE)---
## 📖 Table of Contents
| [Tech Stack](#-tech-stack) | [Features](#-features) | [Prerequisites](#-prerequisites) |
|---------------------------|------------------------|----------------------------------|
| [Setup](#️-setup) | [Project Structure](#️-project-structure) | [Environment Variables](#-environment-variables) |---
### ⚡ Tech Stack
data:image/s3,"s3://crabby-images/fc367/fc367a420142a4ce9c7008b95f8acefc7badb9e2" alt="Terraform"
data:image/s3,"s3://crabby-images/aba6f/aba6f1acf9d4ad41270a4904b80d035f28a52499" alt="GCP"
data:image/s3,"s3://crabby-images/6ec62/6ec625419850a8603d32ad616b79ccc81a9e4b8d" alt="Azure"---
## 🚀 Features
- **Multi-Cloud Support**:
- GCP resource management
- Azure resource management
- Provider-specific configurations
- Resource tagging and organization
- **GCP Configuration**:
- Compute Engine instances
- Network configuration
- Zone and region management
- Resource tagging- **Azure Configuration**:
- Resource Group management
- Virtual Network setup
- Region configuration
- Resource tagging- **Infrastructure Management**:
- Terraform state management
- Provider configuration
- Resource organization
- Multi-environment support## 📦 Prerequisites
- Terraform 1.0+
- GCloud CLI configured
- Azure CLI configured
- GCP account with appropriate permissions
- Azure subscription with appropriate permissions
- Basic understanding of cloud concepts## 🛠️ Setup
1. Clone the repository:
```bash
git clone https://github.com/rafaumeu/multicloud-iac-journey.git
cd multicloud-iac-journey
```2. Initialize Terraform:
```bash
terraform init
```3. Plan the infrastructure:
```bash
terraform plan
```4. Apply the configuration:
```bash
terraform apply
```## 📝 Contributing
### Commit Convention
We follow the [Conventional Commits](https://www.conventionalcommits.org/) specification:
```bash
():[optional body]
[optional footer(s)]
```#### Types
- `feat`: A new feature
- `fix`: A bug fix
- `docs`: Documentation only changes
- `style`: Changes that do not affect the meaning of the code
- `refactor`: A code change that neither fixes a bug nor adds a feature#### Scopes
- `gcp`: Changes to GCP configuration
- `azure`: Changes to Azure configuration
- `aws`: Changes to AWS configuration
- `docs`: Changes to documentation
- `ci`: Changes to CI/CD pipeline## 🏗️ Project Structure
```
multicloud-iac-journey/
├── main.tf # Main configuration file
├── providers.tf # Cloud providers configuration
├── variables.tf # Variable definitions
└── .github/
├── workflows/ # GitHub Actions workflows
└── labeler.yml # PR labeler configuration
```## 🔧 Environment Variables
```bash
# GCP Configuration
GOOGLE_CLOUD_PROJECT="rafael-450215"
GOOGLE_CREDENTIALS="path/to/credentials.json"
```## 📤 Outputs
After applying the infrastructure, you'll get:
- Compute Engine instance details
- Network configuration information
- Resource IDs and names---
Made with ❤️ by Rafael Dias Zendron![]()
[data:image/s3,"s3://crabby-images/7e915/7e915ba70ae0a2bc34f39e537203b1fb61323568" alt="LinkedIn"](https://www.linkedin.com/in/rafael-dias-zendron-528290132/)
[data:image/s3,"s3://crabby-images/88823/88823ce0fa7ba4353317aa4e5949b21ed298c57e" alt="GitHub"](https://github.com/rafaumeu)