-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.tf
93 lines (70 loc) · 1.81 KB
/
main.tf
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
# Configure the Docker provider
provider "docker" {
host = "unix:///var/run/docker.sock"
}
resource "docker_image" "mysql" {
name = "mariadb:10.1.19"
}
resource "docker_image" "pdns" {
name = "pdns4:latest"
}
resource "docker_container" "database" {
image = "${docker_image.mysql.latest}"
name = "powerdns-database"
count = 1
log_driver = "json-file"
log_opts = {
max-size = "1m"
max-file = 2
}
env = ["MYSQL_ROOT_PASSWORD=secretrootpassword", "MYSQL_DATABASE=powerdns", "MYSQL_USER=powerdns", "MYSQL_PASSWORD=powerdns"]
}
resource "null_resource" "wait" {
depends_on = ["docker_container.database"]
provisioner "local-exec" {
command = "echo 'Sleeping for 5...' && sleep 5"
}
}
resource "docker_container" "powerdns" {
depends_on = ["null_resource.wait"]
image = "${docker_image.pdns.latest}"
name = "powerdns"
count = 1
log_driver = "json-file"
log_opts = {
max-size = "1m"
max-file = 2
}
links = ["powerdns-database:database"]
env = ["MYSQL_ROOT_PASSWORD=secretrootpassword", "MYSQL_DATABASE=powerdns", "MYSQL_USER=powerdns", "MYSQL_PASSWORD=powerdns"]
ports {
internal = 80
external = 8080
}
ports {
internal = 53
external = 53
ip = "172.17.0.1"
}
ports {
internal = 53
external = 53
protocol = "udp"
ip = "172.17.0.1"
}
}
/*
# Configure the PowerDNS provider
provider "powerdns" {
api_key = "changeme"
server_url = "http://${docker_container.powerdns.ip_address}"
}
# Add a record to the zone
resource "powerdns_record" "foobar" {
depends_on = ["docker_container.powerdns"]
zone = "crunchyapple.org"
name = "api.crunchyapple.org."
type = "A"
ttl = 300
records = ["8.8.8.8"]
}*/