Quentin
c19cadf353
To do the math: SoGo SxVMemLimit * SoGo WOWorkersCount < Nomad Memory Limit Before we had 384 * 10 >>> 1000 Now we have 300 * 3 < 1000
475 lines
11 KiB
HCL
475 lines
11 KiB
HCL
job "email" {
|
|
datacenters = ["dc1"]
|
|
type = "service"
|
|
|
|
group "dovecot" {
|
|
count = 1
|
|
task "server" {
|
|
driver = "docker"
|
|
|
|
config {
|
|
image = "superboum/amd64_dovecot:v2"
|
|
readonly_rootfs = false
|
|
port_map {
|
|
auth_port = 1337
|
|
imaps_port = 993
|
|
imap_port = 143
|
|
lmtp_port = 24
|
|
}
|
|
command = "dovecot"
|
|
args = [ "-F" ]
|
|
volumes = [
|
|
"secrets/ssl/certs:/etc/ssl/certs",
|
|
"secrets/ssl/private:/etc/ssl/private",
|
|
"secrets/conf/dovecot-ldap.conf:/etc/dovecot/dovecot-ldap.conf",
|
|
"/mnt/glusterfs/email/mail:/var/mail/",
|
|
]
|
|
}
|
|
|
|
env {
|
|
TLSINFO = "/C=FR/ST=Bretagne/L=Rennes/O=Deuxfleurs/CN=imap.deuxfleurs.fr"
|
|
}
|
|
|
|
resources {
|
|
cpu = 100
|
|
memory = 200
|
|
network {
|
|
mbits = 1
|
|
port "auth_port" {
|
|
static = "1337"
|
|
}
|
|
port "imap_port" {
|
|
static = "143"
|
|
}
|
|
port "imaps_port" {
|
|
static = "993"
|
|
}
|
|
port "lmtp_port" {
|
|
static = "24"
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "dovecot-auth"
|
|
port = "auth_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"dovecot",
|
|
]
|
|
check {
|
|
type = "tcp"
|
|
port = "auth_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "dovecot-imap"
|
|
port = "imap_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"dovecot"
|
|
]
|
|
check {
|
|
type = "tcp"
|
|
port = "imap_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "dovecot-imaps"
|
|
port = "imaps_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"dovecot",
|
|
"(diplonat (tcp_port 993))"
|
|
]
|
|
|
|
check {
|
|
type = "tcp"
|
|
port = "imaps_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "dovecot-lmtp"
|
|
port = "lmtp_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"dovecot",
|
|
]
|
|
|
|
check {
|
|
type = "tcp"
|
|
port = "lmtp_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
artifact {
|
|
source = "http://127.0.0.1:8500/v1/kv/configuration/email/dovecot/dovecot-ldap.conf.tpl?raw"
|
|
destination = "secrets/conf/dovecot-ldap.conf.tpl"
|
|
mode = "file"
|
|
}
|
|
template {
|
|
source = "secrets/conf/dovecot-ldap.conf.tpl"
|
|
destination = "secrets/conf/dovecot-ldap.conf"
|
|
perms = "400"
|
|
}
|
|
|
|
template {
|
|
data = "{{ key \"configuration/email/dovecot/dovecot.crt\" }}"
|
|
destination = "secrets/ssl/certs/dovecot.crt"
|
|
perms = "400"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/dovecot/dovecot.key\" }}"
|
|
destination = "secrets/ssl/private/dovecot.key"
|
|
perms = "400"
|
|
}
|
|
}
|
|
}
|
|
|
|
group "opendkim" {
|
|
count = 1
|
|
task "server" {
|
|
driver = "docker"
|
|
|
|
config {
|
|
image = "superboum/amd64_opendkim:v1"
|
|
readonly_rootfs = false
|
|
port_map {
|
|
dkim_port = 8999
|
|
}
|
|
command = "opendkim"
|
|
args = [ "-f", "-v", "-x", "/etc/opendkim.conf" ]
|
|
volumes = [
|
|
"secrets/dkim:/etc/dkim",
|
|
"/dev/log:/dev/log",
|
|
]
|
|
}
|
|
|
|
resources {
|
|
cpu = 100
|
|
memory = 50
|
|
network {
|
|
mbits = 1
|
|
port "dkim_port" {
|
|
static = "8999"
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "opendkim"
|
|
port = "dkim_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"opendkim",
|
|
]
|
|
check {
|
|
type = "tcp"
|
|
port = "dkim_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
template {
|
|
data = "{{ key \"configuration/email/dkim/keytable\" }}"
|
|
destination = "secrets/dkim/keytable"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/dkim/signingtable\" }}"
|
|
destination = "secrets/dkim/signingtable"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/dkim/smtp.private\" }}"
|
|
destination = "secrets/dkim/smtp.private"
|
|
perms = "600"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/dkim/smtp.txt\" }}"
|
|
destination = "secrets/dkim/smtp.txt"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/dkim/trusted\" }}"
|
|
destination = "secrets/dkim/trusted"
|
|
}
|
|
}
|
|
}
|
|
|
|
group "postfix" {
|
|
count = 1
|
|
task "server" {
|
|
driver = "docker"
|
|
|
|
config {
|
|
image = "superboum/amd64_postfix:v1"
|
|
readonly_rootfs = false
|
|
port_map {
|
|
smtp_port = 25
|
|
smtps_port = 465
|
|
submission_port = 587
|
|
}
|
|
command = "postfix"
|
|
args = [ "start-fg" ]
|
|
volumes = [
|
|
"secrets/ssl/certs:/etc/ssl/certs",
|
|
"secrets/ssl/private:/etc/ssl/private",
|
|
"secrets/postfix:/etc/postfix-conf",
|
|
"/dev/log:/dev/log"
|
|
]
|
|
}
|
|
|
|
env {
|
|
TLSINFO = "/C=FR/ST=Bretagne/L=Rennes/O=Deuxfleurs/CN=smtp.deuxfleurs.fr"
|
|
MAILNAME = "smtp.deuxfleurs.fr",
|
|
}
|
|
|
|
resources {
|
|
cpu = 100
|
|
memory = 200
|
|
network {
|
|
mbits = 1
|
|
port "smtp_port" {
|
|
static = "25"
|
|
}
|
|
port "smtps_port" {
|
|
static = "465"
|
|
}
|
|
port "submission_port" {
|
|
static = "587"
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "postfix-smtp"
|
|
port = "smtp_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"postfix",
|
|
"(diplonat (tcp_port 25 465 587))"
|
|
]
|
|
check {
|
|
type = "tcp"
|
|
port = "smtp_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "postfix-smtps"
|
|
port = "smtps_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"postfix",
|
|
]
|
|
|
|
check {
|
|
type = "tcp"
|
|
port = "smtps_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "postfix-submission"
|
|
port = "submission_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"postfix",
|
|
]
|
|
|
|
check {
|
|
type = "tcp"
|
|
port = "submission_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "90s"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
artifact {
|
|
source = "http://127.0.0.1:8500/v1/kv/configuration/email/postfix/ldap-account.cf.tpl?raw"
|
|
destination = "secrets/postfix/ldap-account.cf.tpl"
|
|
mode = "file"
|
|
}
|
|
template {
|
|
source = "secrets/postfix/ldap-account.cf.tpl"
|
|
destination = "secrets/postfix/ldap-account.cf"
|
|
}
|
|
|
|
artifact {
|
|
source = "http://127.0.0.1:8500/v1/kv/configuration/email/postfix/ldap-alias.cf.tpl?raw"
|
|
destination = "secrets/postfix/ldap-alias.cf.tpl"
|
|
mode = "file"
|
|
}
|
|
template {
|
|
source = "secrets/postfix/ldap-alias.cf.tpl"
|
|
destination = "secrets/postfix/ldap-alias.cf"
|
|
}
|
|
|
|
artifact {
|
|
source = "http://127.0.0.1:8500/v1/kv/configuration/email/postfix/ldap-virtual-domains.cf.tpl?raw"
|
|
destination = "secrets/postfix/ldap-virtual-domains.cf.tpl"
|
|
mode = "file"
|
|
}
|
|
template {
|
|
source = "secrets/postfix/ldap-virtual-domains.cf.tpl"
|
|
destination = "secrets/postfix/ldap-virtual-domains.cf"
|
|
}
|
|
|
|
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/postfix.crt\" }}"
|
|
destination = "secrets/ssl/certs/postfix.crt"
|
|
perms = "400"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/postfix.key\" }}"
|
|
destination = "secrets/ssl/private/postfix.key"
|
|
perms = "400"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/dynamicmaps.cf\" }}"
|
|
destination = "secrets/postfix/dynamicmaps.cf"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/header_checks\" }}"
|
|
destination = "secrets/postfix/header_checks"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/main.cf\" }}"
|
|
destination = "secrets/postfix/main.cf"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/master.cf\" }}"
|
|
destination = "secrets/postfix/master.cf"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/transport\" }}"
|
|
destination = "secrets/postfix/transport"
|
|
}
|
|
template {
|
|
data = "{{ key \"configuration/email/postfix/transport.db\" }}"
|
|
destination = "secrets/postfix/transport.db"
|
|
}
|
|
}
|
|
}
|
|
|
|
group "sogo" {
|
|
count = 1
|
|
task "bundle" {
|
|
|
|
driver = "docker"
|
|
|
|
config {
|
|
image = "superboum/amd64_sogo:v7"
|
|
readonly_rootfs = false
|
|
port_map {
|
|
sogo_web_port = 8080
|
|
}
|
|
volumes = [
|
|
"secrets/sogo.conf:/etc/sogo/sogo.conf",
|
|
]
|
|
}
|
|
env {
|
|
FAKE = 1
|
|
}
|
|
|
|
/* Workaround as there is no consul source and no way to template recursively... */
|
|
artifact {
|
|
source = "http://127.0.0.1:8500/v1/kv/configuration/email/sogo/sogo.conf.tpl?raw"
|
|
destination = "secrets/tpl/sogo.conf.tpl"
|
|
mode = "file"
|
|
}
|
|
template {
|
|
source = "secrets/tpl/sogo.conf.tpl"
|
|
destination = "secrets/sogo.conf"
|
|
}
|
|
|
|
resources {
|
|
cpu = 200
|
|
memory = 1000
|
|
network {
|
|
mbits = 1
|
|
port "sogo_web_port" {}
|
|
}
|
|
}
|
|
|
|
service {
|
|
name = "sogo"
|
|
port = "sogo_web_port"
|
|
address_mode = "host"
|
|
tags = [
|
|
"sogo",
|
|
"traefik.enable=true",
|
|
"traefik.frontend.entryPoints=https,http",
|
|
"traefik.frontend.rule=Host:www.sogo.deuxfleurs.fr,sogo.deuxfleurs.fr;PathPrefix:/"
|
|
]
|
|
check {
|
|
type = "tcp"
|
|
port = "sogo_web_port"
|
|
interval = "60s"
|
|
timeout = "5s"
|
|
check_restart {
|
|
limit = 3
|
|
grace = "5m"
|
|
ignore_warnings = false
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
}
|
|
}
|