Compare commits
10 Commits
Author | SHA1 | Date | |
---|---|---|---|
b209942b3d | |||
f821f97b9e | |||
e42ce275c1 | |||
6a9181d1b4 | |||
e07fd1c49d | |||
f2864ecc84 | |||
55a9334df3 | |||
97624cb42d | |||
e8140d8b3f | |||
9f05f09e5d |
6
modules/virtualMachine/locals.tf
Normal file
6
modules/virtualMachine/locals.tf
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
locals {
|
||||||
|
fqdn = "${var.vm_shortname}.${var.vm_domain}"
|
||||||
|
system_image_name = "system.${local.fqdn}"
|
||||||
|
system_image_source = var.system_image_source
|
||||||
|
data_image_name = "data.${local.fqdn}"
|
||||||
|
}
|
@ -1,13 +1,11 @@
|
|||||||
// Dependencies management
|
|
||||||
resource "null_resource" "depends_on" {
|
resource "opennebula_group" "main" {
|
||||||
triggers = {
|
name = var.group
|
||||||
depends_on = join("", var.depends)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// OpenNebula disk image !
|
// OpenNebula disk image !
|
||||||
resource "opennebula_image" "system" {
|
resource "opennebula_image" "system" {
|
||||||
name = var.system_image_name
|
name = local.system_image_name
|
||||||
description = "System disk image"
|
description = "System disk image"
|
||||||
datastore_id = var.one_prod_ds
|
datastore_id = var.one_prod_ds
|
||||||
persistent = false
|
persistent = false
|
||||||
@ -21,7 +19,7 @@ resource "opennebula_image" "system" {
|
|||||||
}
|
}
|
||||||
|
|
||||||
resource "opennebula_image" "data" {
|
resource "opennebula_image" "data" {
|
||||||
name = var.data_image_name
|
name = local.data_image_name
|
||||||
description = "Data disk image"
|
description = "Data disk image"
|
||||||
datastore_id = var.one_prod_ds
|
datastore_id = var.one_prod_ds
|
||||||
persistent = true
|
persistent = true
|
||||||
@ -31,7 +29,7 @@ resource "opennebula_image" "data" {
|
|||||||
driver = "qcow2"
|
driver = "qcow2"
|
||||||
format = "qcow2"
|
format = "qcow2"
|
||||||
permissions = "660"
|
permissions = "660"
|
||||||
group = "production"
|
group = var.group
|
||||||
}
|
}
|
||||||
|
|
||||||
// OpenNebula (VM) Template definition
|
// OpenNebula (VM) Template definition
|
||||||
@ -59,6 +57,10 @@ resource "opennebula_template" "vm_template" {
|
|||||||
image_id = opennebula_image.data.id
|
image_id = opennebula_image.data.id
|
||||||
}
|
}
|
||||||
|
|
||||||
|
os {
|
||||||
|
arch = "x86_64"
|
||||||
|
boot = "disk0,nic0"
|
||||||
|
}
|
||||||
//labels = var.tag_labels
|
//labels = var.tag_labels
|
||||||
|
|
||||||
dynamic "nic" {
|
dynamic "nic" {
|
||||||
@ -78,12 +80,10 @@ resource "opennebula_template" "vm_template" {
|
|||||||
|
|
||||||
// OpenNebula Virtual Machine
|
// OpenNebula Virtual Machine
|
||||||
resource "opennebula_virtual_machine" "vm" {
|
resource "opennebula_virtual_machine" "vm" {
|
||||||
name = var.vm_fqdn
|
name = local.fqdn
|
||||||
group = var.group
|
group = var.group
|
||||||
timeout = 10
|
|
||||||
template_id = opennebula_template.vm_template.id
|
template_id = opennebula_template.vm_template.id
|
||||||
depends_on = [ opennebula_template.vm_template,
|
depends_on = [ opennebula_template.vm_template ]
|
||||||
null_resource.depends_on ]
|
|
||||||
}
|
}
|
||||||
|
|
||||||
resource "dns_a_record_set" "vm_dns_a_record" {
|
resource "dns_a_record_set" "vm_dns_a_record" {
|
||||||
@ -102,7 +102,7 @@ resource "dns_cname_record" "vm_dns_cname_record" {
|
|||||||
|
|
||||||
zone = var.vm_domain
|
zone = var.vm_domain
|
||||||
name = each.value
|
name = each.value
|
||||||
cname = "${var.vm_fqdn}."
|
cname = "${local.fqdn}."
|
||||||
ttl = 300
|
ttl = 300
|
||||||
|
|
||||||
depends_on = [ opennebula_virtual_machine.vm ]
|
depends_on = [ opennebula_virtual_machine.vm ]
|
||||||
|
@ -1,9 +1,13 @@
|
|||||||
output "virtual_machine_shortname" {
|
output "shortname" {
|
||||||
value = opennebula_virtual_machine.vm.name
|
value = opennebula_virtual_machine.vm.name
|
||||||
}
|
}
|
||||||
|
|
||||||
output "virtual_machine_nic0_mac" {
|
output "fqdn" {
|
||||||
value = opennebula_virtual_machine.vm.nic[0].mac
|
value = local.fqdn
|
||||||
|
}
|
||||||
|
|
||||||
|
output "first_nic_mac" {
|
||||||
|
value = opennebula_virtual_machine.vm.template_nic[0].computed_mac
|
||||||
}
|
}
|
||||||
|
|
||||||
output "network_interfaces" {
|
output "network_interfaces" {
|
||||||
|
@ -8,11 +8,6 @@ variable "one_prod_ds" {
|
|||||||
type = string
|
type = string
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "vm_fqdn" {
|
|
||||||
description = "Virtual Machine FQDN Name"
|
|
||||||
type = string
|
|
||||||
}
|
|
||||||
|
|
||||||
variable "vm_shortname" {
|
variable "vm_shortname" {
|
||||||
description = "Virtual machine short name"
|
description = "Virtual machine short name"
|
||||||
type = string
|
type = string
|
||||||
@ -23,24 +18,16 @@ variable "vm_domain" {
|
|||||||
type = string
|
type = string
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "system_image_name" {
|
|
||||||
description = "System image disk name"
|
|
||||||
type = string
|
|
||||||
}
|
|
||||||
|
|
||||||
variable "system_image_source" {
|
variable "system_image_source" {
|
||||||
description = "Virtual Machine system image source"
|
description = "Virtual Machine system image source"
|
||||||
type = string
|
type = string
|
||||||
}
|
default = "https://marketplace.opennebula.io//appliance/251b0578-6c47-4ba4-b184-dc6e873201a2/download/0"
|
||||||
|
|
||||||
variable "data_image_name" {
|
|
||||||
description = "Data image disk name"
|
|
||||||
type = string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "data_image_source" {
|
variable "data_image_source" {
|
||||||
description = "Virtual Machine data disk image source"
|
description = "Virtual Machine data disk image source"
|
||||||
type = string
|
type = string
|
||||||
|
default = "https://marketplace.opennebula.io//appliance/251b0578-6c47-4ba4-b184-dc6e873201a2/download/0"
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "tag_labels" {
|
variable "tag_labels" {
|
||||||
@ -56,16 +43,19 @@ variable "network_interfaces" {
|
|||||||
variable "cpu" {
|
variable "cpu" {
|
||||||
description = "VM CPU"
|
description = "VM CPU"
|
||||||
type = string
|
type = string
|
||||||
|
default = "0.2"
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "vcpu" {
|
variable "vcpu" {
|
||||||
description = "VM vCPU"
|
description = "VM vCPU"
|
||||||
type = string
|
type = string
|
||||||
|
default = "2"
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "ram" {
|
variable "ram" {
|
||||||
description = "VM RAM"
|
description = "VM RAM"
|
||||||
type = string
|
type = string
|
||||||
|
default = "512"
|
||||||
}
|
}
|
||||||
|
|
||||||
variable "depends" {
|
variable "depends" {
|
||||||
@ -105,5 +95,5 @@ variable "graphics" {
|
|||||||
variable "imagemode" {
|
variable "imagemode" {
|
||||||
description = "Disk image mode"
|
description = "Disk image mode"
|
||||||
type = string
|
type = string
|
||||||
default = "0600"
|
default = "600"
|
||||||
}
|
}
|
Reference in New Issue
Block a user