migrate jellyseerr to kubernetes

This commit is contained in:
Pim Kunis 2024-04-06 17:10:34 +02:00
parent babb7ff5b7
commit d46e187abf
3 changed files with 102 additions and 25 deletions

View file

@ -49,31 +49,6 @@ volumes:
jellyfin_cache: jellyfin_cache:
services: services:
jellyseerr:
image: fallenbagel/jellyseerr:1.7.0
environment:
# TODO: fix log level
- LOG_LEVEL=debug
- TZ=Europe/Amsterdam
volumes:
- type: volume
source: jellyseerr_config
target: /app/config
volume:
nocopy: true
networks:
- traefik
deploy:
labels:
- traefik.enable=true
- traefik.http.routers.jellyseerr.entrypoints=localsecure
- traefik.http.routers.jellyseerr.rule=Host(`jellyseerr.kun.is`)
- traefik.http.routers.jellyseerr.tls=true
- traefik.http.routers.jellyseerr.tls.certresolver=letsencrypt
- traefik.http.routers.jellyseerr.service=jellyseerr
- traefik.http.services.jellyseerr.loadbalancer.server.port=5055
- traefik.docker.network=traefik
radarr: radarr:
image: lscr.io/linuxserver/radarr:latest image: lscr.io/linuxserver/radarr:latest
environment: environment:

View file

@ -132,6 +132,12 @@ services:
- traefik.http.routers.transmission.rule=Host(`transmission.kun.is`) - traefik.http.routers.transmission.rule=Host(`transmission.kun.is`)
- traefik.http.routers.transmission.tls=true - traefik.http.routers.transmission.tls=true
- traefik.http.routers.transmission.tls.certresolver=letsencrypt - traefik.http.routers.transmission.tls.certresolver=letsencrypt
- traefik.http.routers.jellyseerr.entrypoints=localsecure
- traefik.http.routers.jellyseerr.service=k3s@file
- traefik.http.routers.jellyseerr.rule=Host(`jellyseerr.kun.is`)
- traefik.http.routers.jellyseerr.tls=true
- traefik.http.routers.jellyseerr.tls.certresolver=letsencrypt
volumes: volumes:
- type: bind - type: bind
source: /var/run/docker.sock source: /var/run/docker.sock

View file

@ -7,6 +7,11 @@
PGID = "1000"; PGID = "1000";
TZ = "Europe/Amsterdam"; TZ = "Europe/Amsterdam";
}; };
jellyseerr-env.data = {
LOG_LEVEL = "debug";
TZ = "Europe/Amsterdam";
};
}; };
deployments = { deployments = {
@ -127,6 +132,49 @@
}; };
}; };
}; };
jellyseerr = {
metadata.labels = {
app = "media";
component = "jellyseerr";
};
spec = {
selector.matchLabels = {
app = "media";
component = "jellyseerr";
};
template = {
metadata.labels = {
app = "media";
component = "jellyseerr";
};
spec = {
containers.jellyseerr = {
image = "fallenbagel/jellyseerr:1.7.0";
envFrom = [{ configMapRef.name = "jellyseerr-env"; }];
ports = [{
containerPort = 5055;
protocol = "TCP";
}];
volumeMounts = [{
name = "config";
mountPath = "/app/config";
}];
};
volumes = [{
name = "config";
persistentVolumeClaim.claimName = "jellyseerr-config";
}];
};
};
};
};
}; };
persistentVolumes = { persistentVolumes = {
@ -159,6 +207,16 @@
path = "/mnt/data/nfs/transmission/config"; path = "/mnt/data/nfs/transmission/config";
}; };
}; };
jellyseerr-config.spec = {
capacity.storage = "1Mi";
accessModes = [ "ReadWriteMany" ];
nfs = {
server = "lewis.hyp";
path = "/mnt/data/nfs/jellyseerr/config";
};
};
}; };
persistentVolumeClaims = { persistentVolumeClaims = {
@ -182,6 +240,13 @@
resources.requests.storage = "1Mi"; resources.requests.storage = "1Mi";
volumeName = "transmission-config"; volumeName = "transmission-config";
}; };
jellyseerr-config.spec = {
accessModes = [ "ReadWriteMany" ];
storageClassName = "";
resources.requests.storage = "1Mi";
volumeName = "jellyseerr-config";
};
}; };
services = { services = {
@ -226,6 +291,19 @@
targetPort = 31780; targetPort = 31780;
}]; }];
}; };
jellyseerr.spec = {
selector = {
app = "media";
component = "jellyseerr";
};
ports = [{
protocol = "TCP";
port = 80;
targetPort = 5055;
}];
};
}; };
ingresses = { ingresses = {
@ -264,6 +342,24 @@
}]; }];
}]; }];
}; };
jellyseerr.spec = {
ingressClassName = "traefik";
rules = [{
host = "jellyseerr.kun.is";
http.paths = [{
path = "/";
pathType = "Prefix";
backend.service = {
name = "jellyseerr";
port.number = 80;
};
}];
}];
};
}; };
}; };
} }