terraform: created terraform-configurations/1/configuration-1.tf
This commit is contained in:
parent
abe719c5ab
commit
f93f1ace6f
69
terraform-configurations/1/configuration-1.tf
Normal file
69
terraform-configurations/1/configuration-1.tf
Normal file
@ -0,0 +1,69 @@
|
|||||||
|
terraform {
|
||||||
|
required_providers {
|
||||||
|
ovh = {
|
||||||
|
source = "ovh/ovh"
|
||||||
|
version = "2.3.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
provider "ovh" {
|
||||||
|
endpoint = "ovh-eu"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable project_id {
|
||||||
|
type = string
|
||||||
|
default = "bc35e9294795473794cf839400e5ad35"
|
||||||
|
}
|
||||||
|
|
||||||
|
variable region {
|
||||||
|
type = string
|
||||||
|
default = "SBG5"
|
||||||
|
}
|
||||||
|
|
||||||
|
// The flavor can be selected directly, name_filter in DS does strict equality
|
||||||
|
data "ovh_cloud_project_flavors" "flavors" {
|
||||||
|
service_name = var.project_id
|
||||||
|
name_filter = "r3-16-flex"
|
||||||
|
region = var.region
|
||||||
|
}
|
||||||
|
|
||||||
|
// The image must be selected from it's region based list using name filtering, DS does not support direct selection
|
||||||
|
data ovh_cloud_project_images image{
|
||||||
|
service_name = var.project_id
|
||||||
|
region = "SBG5"
|
||||||
|
}
|
||||||
|
|
||||||
|
locals {
|
||||||
|
selected_image = one([
|
||||||
|
for m in data.ovh_cloud_project_images.image.images : m if m.name == "Ubuntu 22.04"
|
||||||
|
])
|
||||||
|
selected_flavor = one(data.ovh_cloud_project_flavors.flavors.flavors)
|
||||||
|
}
|
||||||
|
|
||||||
|
resource "ovh_cloud_project_instance" "simpl_vm" {
|
||||||
|
service_name = var.project_id
|
||||||
|
region = var.region
|
||||||
|
billing_period = "hourly"
|
||||||
|
boot_from {
|
||||||
|
image_id = local.selected_image.id
|
||||||
|
}
|
||||||
|
flavor {
|
||||||
|
flavor_id = local.selected_flavor.id
|
||||||
|
}
|
||||||
|
name = "offering-enterprise-server-1-terraform"
|
||||||
|
ssh_key_create {
|
||||||
|
name = "default-user-key"
|
||||||
|
public_key = "ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDjSFhpjNNDz3olIFuLdROifKJXekAu2CKQ7UyziJJOAPD2wP4eYEgTR6R12TnDHMDerNBLo8d/zIhkmmvF8zr4vBgB8nLHHV/hX6J8b1hg9o9ZtFY1czrdgEzjKtEEwqltQANWQqbg2i4cFDC96ZQRm8p/2XlKvdPkudHwnOqa6NtnE5vfBV0tk9uBbvr1mR8f9yMKpeTxyZUqOkhTZq8FIqS1h0n8Sh8CUYpTpsPilSspAs4xd/oR1FdINLGG4g9pJ/iRgsgMesQHb1qs8h/jws/XOE3Dg/+eDR5AsMz1DIuOjfVrT+xSFVtNxRQu5i6/mqad8NjeI+nR/TJjdnyS8k/JQEXWqOYIYOiozeueaP0fuulJuk0hf34dKrQqFp84Mqd7vE/Z4srdbyC1OfxCMhs3j7Ja9eujpAcp0aLl+mUGV9GKKANJlGmnt76YX5SPCKWEQb5plSXEbOkXPNCnJqF/x99AbPluSc3dYqBJmfhtu2w83jo6m+K50/F6eEU= cbeti@LXBU-2N877S3"
|
||||||
|
}
|
||||||
|
network {
|
||||||
|
public = true
|
||||||
|
}
|
||||||
|
user_data = "I2Nsb3VkLWNvbmZpZwojY2xvdWQtY29uZmlnDQpob3N0bmFtZTogZGVmYXVsdC1zZXJ2ZXIgDQpzc2hfcHdhdXRoOiB0cnVlDQpjaHBhc3N3ZDoNCiAgICBleHBpcmU6IGZhbHNlDQp1c2VyczoNCi0gZGVmYXVsdA0KLSBuYW1lOiBhZ3BXNTk1VnYwDQogIHBhc3N3ZDogJDYkcm91bmRzPTQwOTYkcmNSd3lIVGxmSU5Wajl2NyRUOVR6djZZcEdOZkl0eDhFWFViRTExMXZFOTNyYm5WVUNFZVhHeHBBbG9XZTBkRUhsQzZPTTJ2UFFzNzYvSkwxVlV4QkNXV3FjbExTdW1sUXBnTWN1Lw0KICBzaGVsbDogL2Jpbi9iYXNoDQogIGxvY2tfcGFzc3dkOiBmYWxzZQ0KICBzdWRvOiBBTEw9KEFMTCkgTk9QQVNTV0Q6QUxMDQogIGdyb3VwczogdXNlcnMsIGFkbWluLCBzdWRvDQpydW5jbWQ6DQotIGVjaG8gInJlZ2VuZXJhdGluZyBob3N0IGtleXMiDQotIHJtIC1mIC9ldGMvc3NoL3NzaF9ob3N0XyoNCi0gc3NoLWtleWdlbiAtQQ0KLSBlY2hvICJyZXN0YXJ0aW5nIHNzaGQiDQotIHN5c3RlbWN0bCByZXN0YXJ0IHNzaGQNCmRlYnVnOiB0cnVlDQpvdXRwdXQ6DQogIGFsbDogInwgdGVlIC1hIC92YXIvbG9nL2Nsb3VkLWluaXQtZGVidWcubG9nIg0KZmluYWxfbWVzc2FnZTogIkRlZmF1bHQgVk0gQ2xvdWRpbml0IGRvbmUi"
|
||||||
|
}
|
||||||
|
|
||||||
|
// Values defined in outputs are placed in infrastructureDetails
|
||||||
|
output "vmIps" {
|
||||||
|
depends_on = [ovh_cloud_project_instance.simpl_vm]
|
||||||
|
value = tolist(ovh_cloud_project_instance.simpl_vm.addresses[*].ip)
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue
Block a user