mirror of
https://github.com/natelandau/ansible-homelab-config.git
synced 2025-11-18 01:43:40 -05:00
feat(sabnzbd): add nomad job for sabnzbd
This commit is contained in:
100
templates/nomad_jobs/sabnzbd.hcl
Normal file
100
templates/nomad_jobs/sabnzbd.hcl
Normal file
@@ -0,0 +1,100 @@
|
|||||||
|
job "sabnzbd" {
|
||||||
|
region = "global"
|
||||||
|
datacenters = ["{{ datacenter_name }}"]
|
||||||
|
type = "service"
|
||||||
|
|
||||||
|
constraint {
|
||||||
|
attribute = "${node.unique.name}"
|
||||||
|
operator = "regexp"
|
||||||
|
value = "macmini"
|
||||||
|
}
|
||||||
|
|
||||||
|
update {
|
||||||
|
max_parallel = 1
|
||||||
|
health_check = "checks"
|
||||||
|
min_healthy_time = "10s"
|
||||||
|
healthy_deadline = "5m"
|
||||||
|
progress_deadline = "10m"
|
||||||
|
auto_revert = true
|
||||||
|
canary = 0
|
||||||
|
stagger = "30s"
|
||||||
|
}
|
||||||
|
|
||||||
|
group "sabnzbd" {
|
||||||
|
|
||||||
|
count = 1
|
||||||
|
|
||||||
|
restart {
|
||||||
|
attempts = 0
|
||||||
|
delay = "30s"
|
||||||
|
}
|
||||||
|
|
||||||
|
network {
|
||||||
|
port "http" {
|
||||||
|
static = "8080"
|
||||||
|
to = "8080"
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
task "sabnzbd" {
|
||||||
|
|
||||||
|
env {
|
||||||
|
PUID = "${meta.PUID}"
|
||||||
|
PGID = "${meta.PGID}"
|
||||||
|
TZ = "America/New_York"
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
driver = "docker"
|
||||||
|
config {
|
||||||
|
image = "ghcr.io/linuxserver/sabnzbd"
|
||||||
|
hostname = "${NOMAD_TASK_NAME}"
|
||||||
|
volumes = [
|
||||||
|
"${meta.nfsStorageRoot}/pi-cluster/${NOMAD_TASK_NAME}:/config",
|
||||||
|
"${meta.nfsStorageRoot}/media/downloads/nzb:/nzbd",
|
||||||
|
"${meta.nfsStorageRoot}/media/downloads/temp:/incomplete-downloads",
|
||||||
|
"${meta.nfsStorageRoot}/media/downloads/complete:/downloads",
|
||||||
|
"${meta.nfsStorageRoot}/nate:/nate"
|
||||||
|
]
|
||||||
|
ports = ["http"]
|
||||||
|
} // docker config
|
||||||
|
|
||||||
|
service {
|
||||||
|
port = "http"
|
||||||
|
name = "${NOMAD_TASK_NAME}"
|
||||||
|
provider = "nomad"
|
||||||
|
tags = [
|
||||||
|
"traefik.enable=true",
|
||||||
|
"traefik.http.routers.${NOMAD_TASK_NAME}.rule=Host(`sab.{{ homelab_domain_name }}`)",
|
||||||
|
"traefik.http.routers.${NOMAD_TASK_NAME}.entryPoints=web,websecure",
|
||||||
|
"traefik.http.routers.${NOMAD_TASK_NAME}.service=${NOMAD_TASK_NAME}",
|
||||||
|
"traefik.http.routers.${NOMAD_TASK_NAME}.tls=true",
|
||||||
|
"traefik.http.routers.${NOMAD_TASK_NAME}.tls.certresolver=cloudflare",
|
||||||
|
// "traefik.http.routers.${NOMAD_TASK_NAME}.middlewares=authelia@file"
|
||||||
|
]
|
||||||
|
|
||||||
|
check {
|
||||||
|
type = "tcp"
|
||||||
|
port = "http"
|
||||||
|
interval = "30s"
|
||||||
|
timeout = "4s"
|
||||||
|
}
|
||||||
|
check_restart {
|
||||||
|
limit = 0
|
||||||
|
grace = "1m"
|
||||||
|
}
|
||||||
|
} // service
|
||||||
|
|
||||||
|
// resources {
|
||||||
|
// cpu = 100 # MHz
|
||||||
|
// memory = 300 # MB
|
||||||
|
// } // resources
|
||||||
|
|
||||||
|
} // task
|
||||||
|
|
||||||
|
|
||||||
|
} // group
|
||||||
|
|
||||||
|
|
||||||
|
} // job
|
||||||
Reference in New Issue
Block a user