blob: f572df6004785fc0597f1c4b07a4d20dbb520701 (
plain)
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
|
variable "backend_remote_state_address" {
type = "string"
}
variable "backend_remote_state_username" {
type = "string"
}
variable "backend_remote_state_password" {
type = "string"
}
variable "machine_name" {
type = "string"
}
variable "host_name" {
type = "string"
}
variable "uri" {
type = "string"
}
variable "vm_image_and_system" {
type = "string"
}
terraform {
backend "http" {}
}
provider "libvirt" {
uri = "${var.uri}"
}
data "terraform_remote_state" "backend" {
backend = "http"
config {
address = "${var.backend_remote_state_address}"
username = "${var.backend_remote_state_username}"
password = "${var.backend_remote_state_password}"
}
}
resource "local_file" "dnsmasq-config" {
content = "address=/${var.host_name}/${libvirt_domain.main.network_interface.0.addresses.0}"
filename = "/etc/NetworkManager/dnsmasq.d/${var.host_name}.conf"
}
resource "libvirt_domain" "main" {
name = "${var.machine_name}"
memory = "8196"
vcpu = 4
kernel = "${var.vm_image_and_system}/system/kernel/bzImage"
initrd = "${var.vm_image_and_system}/system/initrd"
cmdline {
"--root" = "/dev/vda1"
"--system" = "${var.vm_image_and_system}/system"
"--load" = "${var.vm_image_and_system}/system/boot"
}
filesystem {
source = "/gnu/store"
target = "TAG_gnu_store"
readonly = true
accessmode = "passthrough"
}
disk {
file = "${var.vm_image_and_system}/image"
readonly = true
}
network_interface {
network_name = "${data.terraform_remote_state.backend.network_name}"
wait_for_lease = true
}
console {
type = "pty"
target_port = "0"
target_type = "serial"
}
console {
type = "pty"
target_type = "virtio"
target_port = "1"
}
}
# Outputs
output "mini_environment_up" {
value = "${length(libvirt_domain.main.id) != 0}"
}
|