forked from GuyBarros/nomad_jobs
-
Notifications
You must be signed in to change notification settings - Fork 0
/
nginx-pki.nomad.hcl
118 lines (99 loc) · 2.48 KB
/
nginx-pki.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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
job "nginx" {
datacenters = ["eu-west-2a","eu-west-2b","eu-west-2c","eu-west-2"]
type = "service"
group "withvault" {
count = 5
vault {
policies = ["superuser"]
# namespace = "admin"
env = false
}
network {
port "http" {
to = 80
}
port "https" {
to = 443
}
}
task "nginx-pki" {
driver = "docker"
config {
image = "nginx"
ports = ["http", "https"]
volumes = [
"custom/default.conf:/etc/nginx/conf.d/default.conf",
"secret/cert.key:/etc/nginx/ssl/nginx.key",
]
}
template {
data = <<EOH
server {
listen 80;
listen 443 ssl;
server_name nginx.service.consul;
# note this is slightly wonky using the same file for
# both the cert and key
ssl_certificate /etc/nginx/ssl/nginx.key;
ssl_certificate_key /etc/nginx/ssl/nginx.key;
location / {
root /local/data/;
}
}
EOH
destination = "custom/default.conf"
}
template {
data = <<EOH
{{ with secret "pki/issue/consul-service" "common_name=nginx.service.consul" "ttl=30m" }}
{{ .Data.certificate }}
{{ .Data.private_key }}
{{ end }}
EOH
destination = "secret/cert.key"
}
template {
data = <<EOH
<h2> Hello World </h2>
<br />
<br />
from {{ env "node.unique.name" }}
<br />
running on <b>Nginx Instance-{{ env "NOMAD_ALLOC_INDEX" }} </b>
<br />
<br />
Running in <b> Region {{ env "node.region"}} </b>
<br />
<br />
Running in <b> Datacenter {{ env "node.datacenter"}} </b>
<br />
<br />
{{ with secret "pki/issue/consul-service" "common_name=nginx.service.consul" "ttl=90m" }}
{{ .Data.certificate }}
<br />
<br />
{{ .Data.private_key }}
{{ end }}
EOH
destination = "local/data/nginx-pki/index.html"
}
resources {
cpu = 100 # 100 MHz
memory = 128 # 128 MB
}
service {
name = "nginx-pki"
port = "http"
tags = [
"global",
"urlprefix-/nginx-pki"
]
check {
type = "tcp"
interval = "10s"
timeout = "2s"
}
}
}
}
}