google_compute_network
Html
code posted
by
Y
created at 12 Aug 15:13
Edit
|
Back
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 |
data "google_compute_network" "default" {
name = lookup(var.gke_network_main, "vpc_name")
}
resource "random_string" "db_password" {
length = 16
special = false
lower = true
upper = true
}
resource "google_sql_database_instance" "petstore" {
count = contains(["dev", "prod"], local.envs) ? 1 : 0
name = "petstore"
database_version = "POSTGRES_14"
region = local.us-region
settings {
tier = "db-custom-4-32768"
availability_type = local.envs != "prod" ? "ZONAL" : "REGIONAL"
disk_autoresize = true
disk_type = "PD_SSD"
insights_config {
record_application_tags = false
record_client_address = false
query_insights_enabled = true
query_string_length = 1024
}
database_flags {
name = "cloudsql.enable_pg_cron"
value = "on"
}
backup_configuration {
enabled = true
location = local.us-region
point_in_time_recovery_enabled = true
transaction_log_retention_days = 1
backup_retention_settings {
retained_backups = 7
}
}
ip_configuration {
ipv4_enabled = false
private_network = data.google_compute_network.default.id
}
}
}
resource "google_sql_database" "petstore_db" {
count = contains(["dev", "prod"], local.envs) ? 1 : 0
name = "petstore-db"
instance = google_sql_database_instance.petstore.0.name
}
resource "google_sql_user" "petstore_user" {
count = contains(["dev", "prod"], local.envs) ? 1 : 0
name = "petstore-user"
instance = google_sql_database_instance.petstore.0.name
password = random_string.db_password.result
}
resource "kubernetes_namespace" "petstore" {
provider = kubernetes.gke
metadata {
name = "petstore"
}
}
resource "random_uuid" "uuid" {
}
resource "kubernetes_secret" "session_secret" {
provider = kubernetes.gke
metadata {
name = "session-secret"
namespace = kubernetes_namespace.petstore.metadata[0].name
}
data = {
key = replace(random_uuid.uuid.result, "-", "")
}
type = "Opaque"
}
resource "kubernetes_secret" "sql" {
provider = kubernetes.gke
count = contains(["dev", "prod"], local.envs) ? 1 : 0
metadata {
name = "petstore-db-credentials"
namespace = kubernetes_namespace.petstore.metadata[0].name
}
data = {
DB_USERNAME = google_sql_user.petstore_user.0.name
DB_PASSWORD = google_sql_user.petstore_user.0.password
DB_IP = google_sql_database_instance.petstore.0.private_ip_address
DB_NAME = google_sql_database.petstore_db.0.name
}
type = "Opaque"
}
resource "google_storage_bucket" "petstore_artifacts" {
name = "petstore-artifacts-${local.envs}"
location = "US"
force_destroy = true
}
locals {
envs = var.envs
us-region = "us-central1"
gke = data.terraform_remote_state.core.outputs.gke
} |
3.01 KB in 8 ms with coderay