forked from pierront/but3-iac
compute fait
This commit is contained in:
@@ -25,4 +25,13 @@ module "network" {
|
|||||||
backend_cidr = var.backend_cidr
|
backend_cidr = var.backend_cidr
|
||||||
database_cidr = var.database_cidr
|
database_cidr = var.database_cidr
|
||||||
ssh_source_ranges = var.ssh_source_ranges
|
ssh_source_ranges = var.ssh_source_ranges
|
||||||
|
}
|
||||||
|
|
||||||
|
module "compute" {
|
||||||
|
source = "../../modules/compute"
|
||||||
|
instance_type = var.instance_type
|
||||||
|
zone = var.zone
|
||||||
|
frontend_subnet_id = module.network.subnets.frontend
|
||||||
|
backend_subnet_id = module.network.subnets.backend
|
||||||
|
database_subnet_id = module.network.subnets.database
|
||||||
}
|
}
|
||||||
@@ -40,4 +40,16 @@ variable "project_id" {
|
|||||||
description = "ID du projet"
|
description = "ID du projet"
|
||||||
type = string
|
type = string
|
||||||
default = "glossy-handler-478713-i1"
|
default = "glossy-handler-478713-i1"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable "instance_type" {
|
||||||
|
description = "type de l'instance"
|
||||||
|
type = string
|
||||||
|
default = "e2_small"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable "zone" {
|
||||||
|
description = "Nom de la zone"
|
||||||
|
type = string
|
||||||
|
default = "europe-west9-b"
|
||||||
}
|
}
|
||||||
@@ -19,4 +19,74 @@
|
|||||||
# - Disque : 20GB
|
# - Disque : 20GB
|
||||||
# - Pas d'IP publique
|
# - Pas d'IP publique
|
||||||
# - Tags : database, ssh
|
# - Tags : database, ssh
|
||||||
# - OS Login enabled
|
# - OS Login enabled
|
||||||
|
|
||||||
|
resource "google_compute_instance" "vm_frontend" {
|
||||||
|
name = "vm_frontend"
|
||||||
|
machine_type = var.instance_type
|
||||||
|
zone = var.zone
|
||||||
|
|
||||||
|
boot_disk {
|
||||||
|
initialize_params {
|
||||||
|
image = "debian-cloud/debian-11"
|
||||||
|
size = 10
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
network_interface {
|
||||||
|
access_config {} # IP publique
|
||||||
|
subnetwork = var.frontend_subnet_id
|
||||||
|
}
|
||||||
|
|
||||||
|
tags = ["frontend", "ssh"]
|
||||||
|
|
||||||
|
metadata = {
|
||||||
|
enable-oslogin = "TRUE"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "google_compute_instance" "vm_backend" {
|
||||||
|
name = "vm_backend"
|
||||||
|
machine_type = var.instance_type
|
||||||
|
zone = var.zone
|
||||||
|
|
||||||
|
boot_disk {
|
||||||
|
initialize_params {
|
||||||
|
image = "debian-cloud/debian-11"
|
||||||
|
size = 10
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
network_interface {
|
||||||
|
subnetwork = var.backend_subnet_id
|
||||||
|
}
|
||||||
|
|
||||||
|
tags = ["backend", "ssh"]
|
||||||
|
|
||||||
|
metadata = {
|
||||||
|
enable-oslogin = "TRUE"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "google_compute_instance" "vm_database" {
|
||||||
|
name = "vm_database"
|
||||||
|
machine_type = var.instance_type
|
||||||
|
zone = var.zone
|
||||||
|
|
||||||
|
boot_disk {
|
||||||
|
initialize_params {
|
||||||
|
image = "debian-cloud/debian-11"
|
||||||
|
size = 20
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
network_interface {
|
||||||
|
subnetwork = var.database_subnet_id
|
||||||
|
}
|
||||||
|
|
||||||
|
tags = ["database", "ssh"]
|
||||||
|
|
||||||
|
metadata = {
|
||||||
|
enable-oslogin = "TRUE"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,4 +1,24 @@
|
|||||||
# À vous d'exposer :
|
# À vous d'exposer :
|
||||||
# 1. Les IPs internes de toutes les instances
|
# 1. Les IPs internes de toutes les instances
|
||||||
# 2. L'IP publique du frontend
|
# 2. L'IP publique du frontend
|
||||||
# 3. Les noms des instances
|
# 3. Les noms des instances
|
||||||
|
|
||||||
|
output "ip_internes" {
|
||||||
|
value = {
|
||||||
|
frontend = google_compute_subnetwork.subnet_frontend.network_interface[0].network_ip
|
||||||
|
backend = google_compute_instance.subnet_backend.network_interface[0].network_ip
|
||||||
|
database = google_compute_instance.subnet_database.network_interface[0].network_ip
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
output "ip_public_frontend" {
|
||||||
|
value = google_compute_instance.subnet_frontend.network_interface[0].access_config[0].nat_ip
|
||||||
|
}
|
||||||
|
|
||||||
|
output "nom_instances" {
|
||||||
|
value = {
|
||||||
|
frontend = google_compute_instance.subnet_frontend.name
|
||||||
|
backend = google_compute_instance.subnet_backend.name
|
||||||
|
database = google_compute_instance.subnet_database.name
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -3,4 +3,29 @@
|
|||||||
# - zone
|
# - zone
|
||||||
# - frontend_subnet_id
|
# - frontend_subnet_id
|
||||||
# - backend_subnet_id
|
# - backend_subnet_id
|
||||||
# - database_subnet_id
|
# - database_subnet_id
|
||||||
|
|
||||||
|
variable "instance_type" {
|
||||||
|
description = "type de l'instance"
|
||||||
|
type = string
|
||||||
|
}
|
||||||
|
|
||||||
|
variable "zone" {
|
||||||
|
description = "Nom de la zone"
|
||||||
|
type = string
|
||||||
|
}
|
||||||
|
|
||||||
|
variable "frontend_subnet_id" {
|
||||||
|
description = "id du frontend"
|
||||||
|
type = string
|
||||||
|
}
|
||||||
|
|
||||||
|
variable "backend_subnet_id" {
|
||||||
|
description = "id du backend"
|
||||||
|
type = string
|
||||||
|
}
|
||||||
|
|
||||||
|
variable "database_subnet_id" {
|
||||||
|
description = "id du database"
|
||||||
|
type = string
|
||||||
|
}
|
||||||
|
|||||||
@@ -2,11 +2,11 @@
|
|||||||
# 1. L'ID du VPC
|
# 1. L'ID du VPC
|
||||||
# 2. Les IDs des sous-réseaux sous forme de map
|
# 2. Les IDs des sous-réseaux sous forme de map
|
||||||
|
|
||||||
output "vpc_terraform_output" {
|
output "vpc" {
|
||||||
value = google_compute_network.vpc_terraform.id
|
value = google_compute_network.vpc_terraform.id
|
||||||
}
|
}
|
||||||
|
|
||||||
output "list_id" {
|
output "subnets" {
|
||||||
value = {
|
value = {
|
||||||
frontend = google_compute_subnetwork.subnet_frontend.id
|
frontend = google_compute_subnetwork.subnet_frontend.id
|
||||||
backend = google_compute_subnetwork.subnet_backend.id
|
backend = google_compute_subnetwork.subnet_backend.id
|
||||||
|
|||||||
Reference in New Issue
Block a user