-
Notifications
You must be signed in to change notification settings - Fork 39
/
Copy pathnginx-kv-secret.nomad.hcl
87 lines (72 loc) · 1.57 KB
/
nginx-kv-secret.nomad.hcl
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
job "nginx" {
datacenters = ["eu-west-2","ukwest","sa-east-1","ap-northeast-1","dc1"]
type = "service"
group "nginx" {
count = 3
vault {
policies = ["test"]
change_mode = "restart"
}
task "nginx" {
driver = "docker"
config {
image = "nginx"
port_map {
http = 8080
}
port_map {
https = 443
}
volumes = [
"custom/default.conf:/etc/nginx/conf.d/default.conf"
]
}
template {
data = <<EOH
server {
listen 8080;
server_name nginx.service.consul;
location /nginx-secret {
root /local/data;
}
}
EOH
destination = "custom/default.conf"
}
# vault write secret/motd ttl=10s message='Live demos rock!!!'
template {
data = <<EOH
from ${NOMAD_ADDR_http}
{{ with secret "secret/test" }}
secret: {{ .Data.message }}
{{ end }}
EOH
destination = "local/data/nginx-secret/index.html"
}
resources {
cpu = 100 # 100 MHz
memory = 128 # 128 MB
network {
mbits = 10
port "http" {
}
port "https" {
}
}
}
service {
name = "nginx"
tags = [
"global",
"urlprefix-/nginx-secret"
]
port = "http"
check {
type = "tcp"
interval = "10s"
timeout = "2s"
}
}
}
}
}