287 lines
9.5 KiB
YAML
287 lines
9.5 KiB
YAML
version: "3"
|
|
services:
|
|
radarr:
|
|
image: linuxserver/radarr
|
|
container_name: autopirate_radarr
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
networks:
|
|
- web
|
|
environment:
|
|
- PUID=1000
|
|
- PGID=1000
|
|
- TZ=America/Los_Angeles
|
|
volumes:
|
|
- "${MEDIA_DIR}/Video/Movies:/movies"
|
|
- "${DOCKER_DATA}/radarr_config:/config"
|
|
- "${NZB_DIR}:/downloads"
|
|
labels:
|
|
- traefik.http.routers.radarr.rule=Host(`radarr.jafner.net`)
|
|
- traefik.http.routers.radarr.tls.certresolver=lets-encrypt
|
|
- traefik.http.services.radarr.loadbalancer.server.port=7878
|
|
- traefik.http.routers.radarr.middlewares=authentik@file,lan-only@file
|
|
# - traefik.http.routers.radarr.priority=10
|
|
# - traefik.http.routers.radarr-auth.rule=Host(`radarr.jafner.net`) && PathPrefix(`/outpost.goauthentik.io/`)
|
|
# - traefik.http.routers.radarr-auth.priority=15
|
|
# - traefik.http.routers.radarr-auth.service=authentik-auth@file
|
|
|
|
|
|
sonarr:
|
|
image: linuxserver/sonarr
|
|
container_name: autopirate_sonarr
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
networks:
|
|
- web
|
|
environment:
|
|
- PUID=1000
|
|
- PGID=1000
|
|
- TZ=America/Los_Angeles
|
|
volumes:
|
|
- "${MEDIA_DIR}/Video/Shows:/shows"
|
|
- "${DOCKER_DATA}/sonarr_config:/config"
|
|
- "${NZB_DIR}:/downloads"
|
|
labels:
|
|
- traefik.http.routers.sonarr.rule=Host(`sonarr.jafner.net`)
|
|
- traefik.http.routers.sonarr.tls.certresolver=lets-encrypt
|
|
- traefik.http.services.sonarr.loadbalancer.server.port=8989
|
|
- traefik.http.routers.sonarr.middlewares=authentik@file,lan-only@file
|
|
# - traefik.http.routers.sonarr.priority=10
|
|
# - traefik.http.routers.sonarr-auth.rule=Host(`sonarr.jafner.net`) && PathPrefix(`/outpost.goauthentik.io/`)
|
|
# - traefik.http.routers.sonarr-auth.priority=15
|
|
# - traefik.http.routers.sonarr-auth.service=http://authentik-server:9000/outpost.goauthentik.io
|
|
|
|
lidarr:
|
|
image: linuxserver/lidarr
|
|
container_name: autopirate_lidarr
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
networks:
|
|
- web
|
|
environment:
|
|
- PUID=1000
|
|
- PGID=1000
|
|
- TZ=America/Los_Angeles
|
|
volumes:
|
|
- "${DOCKER_DATA}/lidarr:/config"
|
|
- "${NZB_DIR}:/downloads"
|
|
- "${MEDIA_DIR}/Audio/Music:/music"
|
|
labels:
|
|
- traefik.http.routers.lidarr.rule=Host(`lidarr.jafner.net`)
|
|
- traefik.http.routers.lidarr.tls.certresolver=lets-encrypt
|
|
- trarfik.http.services.lidarr.loadbalancer.server.port=8686
|
|
- traefik.http.routers.lidarr.middlewares=authentik@file,lan-only@file
|
|
# - traefik.http.routers.lidarr.priority=10
|
|
# - traefik.http.routers.lidarr-auth.rule=Host(`lidarr.jafner.net`) && PathPrefix(`/outpost.goauthentik.io/`)
|
|
# - traefik.http.routers.lidarr-auth.priority=15
|
|
# - traefik.http.routers.lidarr-auth.service=http://authentik-server:9000/outpost.goauthentik.io
|
|
|
|
nzbhydra2:
|
|
image: linuxserver/nzbhydra2
|
|
container_name: autopirate_nzbhydra2
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
networks:
|
|
- web
|
|
environment:
|
|
- PUID=1000
|
|
- PGID=1000
|
|
- TZ=America/Los_Angeles
|
|
volumes:
|
|
- "${DOCKER_DATA}/nzbhydra2_config:/config"
|
|
- "${NZB_DIR}:/downloads"
|
|
labels:
|
|
- traefik.http.routers.nzbhydra2.rule=Host(`nzbhydra.jafner.net`)
|
|
- traefik.http.routers.nzbhydra2.tls.certresolver=lets-encrypt
|
|
- traefik.http.services.nzbhydra2.loadbalancer.server.port=5076
|
|
- traefik.http.routers.nzbhydra2.middlewares=authentik@file,lan-only@file
|
|
# - traefik.http.routers.nzbhydra2.priority=10
|
|
# - traefik.http.routers.nzbhydra2-auth.rule=Host(`nzbhydra.jafner.net`) && PathPrefix(`/outpost.goauthentik.io/`)
|
|
# - traefik.http.routers.nzbhydra2-auth.priority=15
|
|
# - traefik.http.routers.nzbhydra2-auth.service=http://authentik-server:9000/outpost.goauthentik.io
|
|
|
|
sabnzbd:
|
|
image: linuxserver/sabnzbd
|
|
container_name: autopirate_sabnzbd
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
networks:
|
|
- web
|
|
- monitoring
|
|
environment:
|
|
- PUID=1000
|
|
- PGID=1000
|
|
- TZ=America/Los_Angeles
|
|
ports:
|
|
- 8085:8080
|
|
volumes:
|
|
- "${DOCKER_DATA}/sabnzbd_config:/config"
|
|
- "${NZB_DIR}:/downloads"
|
|
- "${INCOMPLETE_NZB_DIR}:/incomplete-downloads"
|
|
labels:
|
|
- traefik.http.routers.sabnzbd.rule=Host(`sabnzbd.jafner.net`)
|
|
- traefik.http.routers.sabnzbd.tls.certresolver=lets-encrypt
|
|
- traefik.http.services.sabnzbd.loadbalancer.server.port=8080
|
|
- traefik.http.routers.sabnzbd.middlewares=authentik@file,lan-only@file
|
|
# - traefik.http.routers.sabnzbd.priority=10
|
|
# - traefik.http.routers.sabnzbd-auth.rule=Host(`sabnzbd.jafner.net`) && PathPrefix(`/outpost.goauthentik.io/`)
|
|
# - traefik.http.routers.sabnzbd-auth.priority=15
|
|
# - traefik.http.routers.sabnzbd-auth.service=http://authentik-server:9000/outpost.goauthentik.io
|
|
|
|
tdarr:
|
|
image: haveagitgat/tdarr:latest
|
|
container_name: autopirate_tdarr
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
networks:
|
|
web:
|
|
tdarr:
|
|
ipv4_address: 172.110.0.10
|
|
ports:
|
|
- 8265:8265 # webUI port
|
|
- 8266:8266 # server port
|
|
- 8267:8267 # node port
|
|
labels:
|
|
- traefik.http.routers.tdarr.rule=Host(`tdarr.jafner.net`)
|
|
- traefik.http.routers.tdarr.tls.certresolver=lets-encrypt
|
|
- traefik.http.routers.tdarr.middlewares=authentik@file,lan-only@file
|
|
- traefik.http.services.tdarr.loadbalancer.server.port=8265
|
|
# - traefik.http.routers.tdarr.priority=10
|
|
# - traefik.http.routers.tdarr-auth.rule=Host(`tdarr.jafner.net`) && PathPrefix(`/outpost.goauthentik.io/`)
|
|
# - traefik.http.routers.tdarr-auth.priority=15
|
|
# - traefik.http.routers.tdarr-auth.service=http://authentik-server:9000/outpost.goauthentik.io
|
|
environment:
|
|
- TZ=${TZ}
|
|
- PUID=${PUID}
|
|
- PGID=${PGID}
|
|
- UMASK_SET=002
|
|
- serverIP=0.0.0.0
|
|
- serverPort=8266
|
|
- webUIPort=8265
|
|
volumes:
|
|
- ${DOCKER_DATA}/tdarr/server:/app/server
|
|
- ${DOCKER_DATA}/tdarr/configs:/app/configs
|
|
- ${DOCKER_DATA}/tdarr/logs:/app/logs
|
|
- ${MEDIA_DIR}/Video/Movies:/movies
|
|
- ${MEDIA_DIR}/Video/Shows:/shows
|
|
- ${TRANSCODE_DIR}/transcode_cache:/temp
|
|
|
|
tdarr-node:
|
|
image: haveagitgat/tdarr_node:latest
|
|
container_name: autopirate_tdarr-node
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
deploy:
|
|
resources:
|
|
reservations:
|
|
devices:
|
|
- driver: nvidia
|
|
count: all
|
|
capabilities: [gpu]
|
|
limits:
|
|
cpus: '12.00'
|
|
networks:
|
|
tdarr:
|
|
ipv4_address: 172.110.0.20
|
|
environment:
|
|
- TZ=${TZ}
|
|
- PUID=${PUID}
|
|
- PGID=${PGID}
|
|
- UMASK_SET=002
|
|
- nodeID=MainNode
|
|
- nodeIP=172.110.0.20
|
|
- nodePort=8267
|
|
- serverIP=172.110.0.10
|
|
- serverPort=8266
|
|
- NVIDIA_VISIBLE_DEVICES=all
|
|
- NVIDIA_DRIVER_CAPABILITIES=all
|
|
volumes:
|
|
- ${DOCKER_DATA}/tdarr/configs:/app/configs
|
|
- ${DOCKER_DATA}/tdarr/logs:/app/logs
|
|
- ${MEDIA_DIR}/Video/Movies:/movies
|
|
- ${MEDIA_DIR}/Video/Shows:/shows
|
|
- ${TRANSCODE_DIR}/transcode_cache:/temp
|
|
|
|
jackett:
|
|
image: linuxserver/jackett
|
|
container_name: autopirate_jackett
|
|
logging:
|
|
driver: loki
|
|
options:
|
|
loki-url: http://localhost:3100/loki/api/v1/push
|
|
loki-batch-size: "50"
|
|
loki-retries: "1"
|
|
loki-timeout: "2s"
|
|
keep-file: "true"
|
|
networks:
|
|
- web
|
|
environment:
|
|
- PUID=1000
|
|
- PGID=1000
|
|
- TZ=America/Los_Angeles
|
|
- AUTO_UPDATE=false
|
|
volumes:
|
|
- "${DOCKER_DATA}/jackett_config:/config"
|
|
- "${NZB_DIR}:/downloads"
|
|
labels:
|
|
- traefik.http.routers.jackett.rule=Host(`jackett.jafner.net`)
|
|
- traefik.http.routers.jackett.tls.certresolver=lets-encrypt
|
|
- traefik.http.services.jackett.loadbalancer.server.port=9117
|
|
- traefik.http.routers.jackett.middlewares=authentik@file,lan-only@file
|
|
# - traefik.http.routers.jackett.priority=10
|
|
# - traefik.http.routers.jackett-auth.rule=Host(`jackett.jafner.net`) && PathPrefix(`/outpost.goauthentik.io/`)
|
|
# - traefik.http.routers.jackett-auth.priority=15
|
|
# - traefik.http.routers.jackett-auth.service=http://authentik-server:9000/outpost.goauthentik.io
|
|
|
|
networks:
|
|
tdarr:
|
|
ipam:
|
|
driver: default
|
|
config:
|
|
- subnet: "172.110.0.0/24"
|
|
web:
|
|
external: true
|
|
monitoring:
|
|
external: true |