Compare commits
1 commit
0354c037de
...
cc0b054979
| Author | SHA1 | Date | |
|---|---|---|---|
| cc0b054979 |
43 changed files with 107 additions and 887 deletions
|
|
@ -311,34 +311,3 @@ extraObjects:
|
||||||
kind: ClusterRole
|
kind: ClusterRole
|
||||||
name: argo-workflows-view
|
name: argo-workflows-view
|
||||||
apiGroup: rbac.authorization.k8s.io
|
apiGroup: rbac.authorization.k8s.io
|
||||||
- apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
kind: Role
|
|
||||||
metadata:
|
|
||||||
name: argo-workflows-server-sso
|
|
||||||
namespace: argo-workflows
|
|
||||||
rules:
|
|
||||||
- apiGroups:
|
|
||||||
- ""
|
|
||||||
resources:
|
|
||||||
- serviceaccounts
|
|
||||||
verbs:
|
|
||||||
- get
|
|
||||||
- apiGroups:
|
|
||||||
- ""
|
|
||||||
resources:
|
|
||||||
- serviceaccounts/token
|
|
||||||
verbs:
|
|
||||||
- create
|
|
||||||
- apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
kind: RoleBinding
|
|
||||||
metadata:
|
|
||||||
name: argo-workflows-server-sso
|
|
||||||
namespace: argo-workflows
|
|
||||||
subjects:
|
|
||||||
- kind: ServiceAccount
|
|
||||||
name: argo-workflows-server
|
|
||||||
namespace: argo-workflows
|
|
||||||
roleRef:
|
|
||||||
kind: Role
|
|
||||||
name: argo-workflows-server-sso
|
|
||||||
apiGroup: rbac.authorization.k8s.io
|
|
||||||
|
|
|
||||||
|
|
@ -216,22 +216,3 @@ spec:
|
||||||
automated:
|
automated:
|
||||||
prune: true
|
prune: true
|
||||||
selfHeal: true
|
selfHeal: true
|
||||||
---
|
|
||||||
apiVersion: argoproj.io/v1alpha1
|
|
||||||
kind: Application
|
|
||||||
metadata:
|
|
||||||
name: romm
|
|
||||||
namespace: argocd
|
|
||||||
spec:
|
|
||||||
project: default
|
|
||||||
source:
|
|
||||||
repoURL: https://code.peterg.nl/wheatley/kubernetes.git
|
|
||||||
path: k8s-wheatley/romm
|
|
||||||
targetRevision: HEAD
|
|
||||||
destination:
|
|
||||||
server: https://10.13.37.10:6443
|
|
||||||
namespace: romm
|
|
||||||
syncPolicy:
|
|
||||||
automated:
|
|
||||||
prune: true
|
|
||||||
selfHeal: true
|
|
||||||
|
|
|
||||||
|
|
@ -12,4 +12,4 @@ helmCharts:
|
||||||
repo: https://charts.external-secrets.io
|
repo: https://charts.external-secrets.io
|
||||||
namespace: external-secrets
|
namespace: external-secrets
|
||||||
releaseName: external-secrets
|
releaseName: external-secrets
|
||||||
version: 2.5.0
|
version: 2.4.1
|
||||||
|
|
|
||||||
|
|
@ -12,4 +12,4 @@ helmCharts:
|
||||||
repo: https://charts.external-secrets.io
|
repo: https://charts.external-secrets.io
|
||||||
namespace: external-secrets
|
namespace: external-secrets
|
||||||
releaseName: external-secrets
|
releaseName: external-secrets
|
||||||
version: 2.5.0
|
version: 2.4.1
|
||||||
|
|
|
||||||
|
|
@ -28,10 +28,8 @@ spec:
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- mountPath: /config
|
- mountPath: /config
|
||||||
name: lidarr-config
|
name: lidarr-config
|
||||||
- mountPath: /shared/media/music
|
- mountPath: /shared/media
|
||||||
name: nfs-media-music
|
name: nfs-media
|
||||||
- mountPath: /shared/media/downloads
|
|
||||||
name: nfs-media-downloads
|
|
||||||
securityContext:
|
securityContext:
|
||||||
seccompProfile:
|
seccompProfile:
|
||||||
type: RuntimeDefault
|
type: RuntimeDefault
|
||||||
|
|
@ -47,9 +45,6 @@ spec:
|
||||||
- name: lidarr-config
|
- name: lidarr-config
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: lidarr-storage
|
claimName: lidarr-storage
|
||||||
- name: nfs-media-music
|
- name: nfs-media
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: nfs-media-music
|
claimName: nfs-media
|
||||||
- name: nfs-media-downloads
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-downloads
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ kind: Kustomization
|
||||||
namespace: lidarr
|
namespace: lidarr
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
|
- ../../kustomize-bases/nfs-media
|
||||||
- configmap.yaml
|
- configmap.yaml
|
||||||
- deployments.yaml
|
- deployments.yaml
|
||||||
- ingress.yaml
|
- ingress.yaml
|
||||||
|
|
@ -11,40 +12,22 @@ resources:
|
||||||
- services.yaml
|
- services.yaml
|
||||||
- namespace.yaml
|
- namespace.yaml
|
||||||
|
|
||||||
components:
|
|
||||||
- ../../kustomize-bases/nfs-media/components/music
|
|
||||||
- ../../kustomize-bases/nfs-media/components/downloads
|
|
||||||
|
|
||||||
patches:
|
patches:
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolume
|
kind: PersistentVolume
|
||||||
name: nfs-media-music
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /metadata/name
|
path: /metadata/name
|
||||||
value: nfs-media-lidarr-music
|
value: nfs-media-lidarr
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolumeClaim
|
kind: PersistentVolumeClaim
|
||||||
name: nfs-media-music
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /spec/volumeName
|
path: /spec/volumeName
|
||||||
value: nfs-media-lidarr-music
|
value: nfs-media-lidarr
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-lidarr-downloads
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-lidarr-downloads
|
|
||||||
|
|
||||||
images:
|
images:
|
||||||
- name: linuxserver/lidarr
|
- name: linuxserver/lidarr
|
||||||
newTag: 3.1.2-nightly
|
newTag: 3.1.0@sha256:d2f944115de2ca6754ad142ee92f9db481b1574c7bc030974d624584106b78d7
|
||||||
|
|
|
||||||
|
|
@ -9,4 +9,4 @@ spec:
|
||||||
- ReadWriteOnce
|
- ReadWriteOnce
|
||||||
resources:
|
resources:
|
||||||
requests:
|
requests:
|
||||||
storage: 10Gi
|
storage: 5Gi
|
||||||
|
|
|
||||||
|
|
@ -28,12 +28,8 @@ spec:
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- mountPath: /config
|
- mountPath: /config
|
||||||
name: plex-config
|
name: plex-config
|
||||||
- mountPath: /data/movies
|
- mountPath: /data
|
||||||
name: nfs-media-movies
|
name: nfs-media
|
||||||
- mountPath: /data/series
|
|
||||||
name: nfs-media-series
|
|
||||||
- mountPath: /data/anime
|
|
||||||
name: nfs-media-anime
|
|
||||||
securityContext:
|
securityContext:
|
||||||
seccompProfile:
|
seccompProfile:
|
||||||
type: RuntimeDefault
|
type: RuntimeDefault
|
||||||
|
|
@ -49,12 +45,6 @@ spec:
|
||||||
- name: plex-config
|
- name: plex-config
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: plex-storage
|
claimName: plex-storage
|
||||||
- name: nfs-media-movies
|
- name: nfs-media
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: nfs-media-movies
|
claimName: nfs-media
|
||||||
- name: nfs-media-series
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-series
|
|
||||||
- name: nfs-media-anime
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-anime
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ kind: Kustomization
|
||||||
namespace: plex
|
namespace: plex
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
|
- ../../kustomize-bases/nfs-media
|
||||||
- configmap.yaml
|
- configmap.yaml
|
||||||
- deployments.yaml
|
- deployments.yaml
|
||||||
- ingress.yaml
|
- ingress.yaml
|
||||||
|
|
@ -12,69 +13,24 @@ resources:
|
||||||
- services.yaml
|
- services.yaml
|
||||||
- namespace.yaml
|
- namespace.yaml
|
||||||
|
|
||||||
components:
|
|
||||||
- ../../kustomize-bases/nfs-media/components/movies
|
|
||||||
- ../../kustomize-bases/nfs-media/components/series
|
|
||||||
- ../../kustomize-bases/nfs-media/components/anime
|
|
||||||
|
|
||||||
patches:
|
patches:
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolume
|
kind: PersistentVolume
|
||||||
name: nfs-media-movies
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /metadata/name
|
path: /metadata/name
|
||||||
value: nfs-media-plex-movies
|
value: nfs-media-plex
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /spec/accessModes/0
|
path: /spec/accessModes/0
|
||||||
value: ReadOnlyMany
|
value: ReadOnlyMany
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolumeClaim
|
kind: PersistentVolumeClaim
|
||||||
name: nfs-media-movies
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /spec/volumeName
|
path: /spec/volumeName
|
||||||
value: nfs-media-plex-movies
|
value: nfs-media-plex
|
||||||
- op: replace
|
|
||||||
path: /spec/accessModes/0
|
|
||||||
value: ReadOnlyMany
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-series
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-plex-series
|
|
||||||
- op: replace
|
|
||||||
path: /spec/accessModes/0
|
|
||||||
value: ReadOnlyMany
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-series
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-plex-series
|
|
||||||
- op: replace
|
|
||||||
path: /spec/accessModes/0
|
|
||||||
value: ReadOnlyMany
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-anime
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-plex-anime
|
|
||||||
- op: replace
|
|
||||||
path: /spec/accessModes/0
|
|
||||||
value: ReadOnlyMany
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-anime
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-plex-anime
|
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /spec/accessModes/0
|
path: /spec/accessModes/0
|
||||||
value: ReadOnlyMany
|
value: ReadOnlyMany
|
||||||
|
|
|
||||||
|
|
@ -12,7 +12,7 @@ data:
|
||||||
VPN_PORT_FORWARDING_UP_COMMAND: "/scripts/port-up.sh"
|
VPN_PORT_FORWARDING_UP_COMMAND: "/scripts/port-up.sh"
|
||||||
VPN_PORT_FORWARDING_DOWN_COMMAND: "/scripts/port-down.sh"
|
VPN_PORT_FORWARDING_DOWN_COMMAND: "/scripts/port-down.sh"
|
||||||
FIREWALL_OUTBOUND_SUBNETS: 10.244.0.0/16,10.96.0.0/12
|
FIREWALL_OUTBOUND_SUBNETS: 10.244.0.0/16,10.96.0.0/12
|
||||||
FIREWALL_INPUT_PORTS: "8112,5030"
|
FIREWALL_INPUT_PORTS: "8112"
|
||||||
---
|
---
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: ConfigMap
|
kind: ConfigMap
|
||||||
|
|
@ -43,22 +43,6 @@ data:
|
||||||
---
|
---
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: ConfigMap
|
kind: ConfigMap
|
||||||
metadata:
|
|
||||||
name: slskd-envs
|
|
||||||
data:
|
|
||||||
TZ: Europe/Amsterdam
|
|
||||||
PUID: "1000"
|
|
||||||
PGID: "1000"
|
|
||||||
SLSKD_DOWNLOADS_DIR: /shared/media/downloads/_slsk-downloads
|
|
||||||
SLSKD_INCOMPLETE_DIR: /shared/media/downloads/_slsk-incomplete
|
|
||||||
SLSKD_SHARED_DIR: "[Music]/shared/media/downloads/_slsk-downloads"
|
|
||||||
SLSKD_REMOTE_CONFIGURATION: "true"
|
|
||||||
SLSKD_VPN: "true"
|
|
||||||
SLSKD_VPN_PORT_FORWARDING: "true"
|
|
||||||
SLSKD_VPN_GLUETUN_URL: http://localhost:8000
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: ConfigMap
|
|
||||||
metadata:
|
metadata:
|
||||||
name: unpackerr-envs
|
name: unpackerr-envs
|
||||||
data:
|
data:
|
||||||
|
|
|
||||||
|
|
@ -21,21 +21,16 @@ spec:
|
||||||
- name: gluetun
|
- name: gluetun
|
||||||
image: ghcr.io/qdm12/gluetun
|
image: ghcr.io/qdm12/gluetun
|
||||||
ports:
|
ports:
|
||||||
- name: qbit-http
|
- name: http
|
||||||
containerPort: 8112
|
containerPort: 8112
|
||||||
protocol: TCP
|
protocol: TCP
|
||||||
- name: slskd-http
|
|
||||||
containerPort: 5030
|
|
||||||
protocol: TCP
|
|
||||||
envFrom:
|
envFrom:
|
||||||
- configMapRef:
|
- configMapRef:
|
||||||
name: gluetun-envs
|
name: gluetun-envs
|
||||||
- secretRef:
|
|
||||||
name: gluetun-env-secrets
|
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- mountPath: /dev/net/tun
|
- mountPath: /dev/net/tun
|
||||||
name: dev-tun
|
name: dev-tun
|
||||||
- mountPath: /gluetun/wireguard
|
- mountPath: "/gluetun/wireguard"
|
||||||
name: gluetun-wgconfig
|
name: gluetun-wgconfig
|
||||||
readOnly: true
|
readOnly: true
|
||||||
- name: gluetun-scripts
|
- name: gluetun-scripts
|
||||||
|
|
@ -94,7 +89,7 @@ spec:
|
||||||
- mountPath: /config
|
- mountPath: /config
|
||||||
name: qbittorrent-config
|
name: qbittorrent-config
|
||||||
- mountPath: /shared/media/downloads
|
- mountPath: /shared/media/downloads
|
||||||
name: nfs-media-downloads
|
name: nfs-media
|
||||||
securityContext:
|
securityContext:
|
||||||
seccompProfile:
|
seccompProfile:
|
||||||
type: RuntimeDefault
|
type: RuntimeDefault
|
||||||
|
|
@ -114,7 +109,7 @@ spec:
|
||||||
name: unpackerr-env-secrets
|
name: unpackerr-env-secrets
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- mountPath: /shared/media/downloads
|
- mountPath: /shared/media/downloads
|
||||||
name: nfs-media-downloads
|
name: nfs-media
|
||||||
securityContext:
|
securityContext:
|
||||||
seccompProfile:
|
seccompProfile:
|
||||||
type: RuntimeDefault
|
type: RuntimeDefault
|
||||||
|
|
@ -124,30 +119,6 @@ spec:
|
||||||
capabilities:
|
capabilities:
|
||||||
drop:
|
drop:
|
||||||
- "ALL"
|
- "ALL"
|
||||||
- name: slskd
|
|
||||||
image: docker.io/slskd/slskd
|
|
||||||
imagePullPolicy: IfNotPresent
|
|
||||||
envFrom:
|
|
||||||
- configMapRef:
|
|
||||||
name: slskd-envs
|
|
||||||
- secretRef:
|
|
||||||
name: slskd-env-secrets
|
|
||||||
volumeMounts:
|
|
||||||
- mountPath: /config
|
|
||||||
name: slskd-config
|
|
||||||
- mountPath: /shared/media/downloads
|
|
||||||
name: nfs-media-downloads
|
|
||||||
securityContext:
|
|
||||||
seccompProfile:
|
|
||||||
type: RuntimeDefault
|
|
||||||
allowPrivilegeEscalation: false
|
|
||||||
capabilities:
|
|
||||||
drop:
|
|
||||||
- "ALL"
|
|
||||||
add:
|
|
||||||
- "CHOWN"
|
|
||||||
- "SETUID"
|
|
||||||
- "SETGID"
|
|
||||||
volumes:
|
volumes:
|
||||||
- name: dev-tun
|
- name: dev-tun
|
||||||
hostPath:
|
hostPath:
|
||||||
|
|
@ -156,9 +127,6 @@ spec:
|
||||||
- name: qbittorrent-config
|
- name: qbittorrent-config
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: qbittorrent-storage
|
claimName: qbittorrent-storage
|
||||||
- name: slskd-config
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: slskd-storage
|
|
||||||
- name: gluetun-wgconfig
|
- name: gluetun-wgconfig
|
||||||
secret:
|
secret:
|
||||||
secretName: gluetun-wgconfig
|
secretName: gluetun-wgconfig
|
||||||
|
|
@ -168,6 +136,6 @@ spec:
|
||||||
defaultMode: 0755
|
defaultMode: 0755
|
||||||
- name: gluetun-tmp
|
- name: gluetun-tmp
|
||||||
emptyDir: {}
|
emptyDir: {}
|
||||||
- name: nfs-media-downloads
|
- name: nfs-media
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: nfs-media-downloads
|
claimName: nfs-media
|
||||||
|
|
|
||||||
|
|
@ -14,46 +14,3 @@ spec:
|
||||||
- backendRefs:
|
- backendRefs:
|
||||||
- name: qbittorrent
|
- name: qbittorrent
|
||||||
port: 80
|
port: 80
|
||||||
|
|
||||||
---
|
|
||||||
apiVersion: gateway.networking.k8s.io/v1
|
|
||||||
kind: HTTPRoute
|
|
||||||
metadata:
|
|
||||||
name: slskd-route
|
|
||||||
spec:
|
|
||||||
parentRefs:
|
|
||||||
- name: internal
|
|
||||||
namespace: kube-system
|
|
||||||
sectionName: https
|
|
||||||
hostnames:
|
|
||||||
- "slskd.wheatley.in"
|
|
||||||
rules:
|
|
||||||
- backendRefs:
|
|
||||||
- name: slskd
|
|
||||||
port: 80
|
|
||||||
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Service
|
|
||||||
metadata:
|
|
||||||
name: qbittorrent
|
|
||||||
spec:
|
|
||||||
selector:
|
|
||||||
app: qbittorrent
|
|
||||||
ports:
|
|
||||||
- port: 80
|
|
||||||
protocol: TCP
|
|
||||||
targetPort: 8112
|
|
||||||
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Service
|
|
||||||
metadata:
|
|
||||||
name: slskd
|
|
||||||
spec:
|
|
||||||
selector:
|
|
||||||
app: qbittorrent
|
|
||||||
ports:
|
|
||||||
- port: 80
|
|
||||||
protocol: TCP
|
|
||||||
targetPort: 5030
|
|
||||||
|
|
|
||||||
|
|
@ -4,36 +4,36 @@ kind: Kustomization
|
||||||
namespace: qbittorrent
|
namespace: qbittorrent
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
|
- ../../kustomize-bases/nfs-media
|
||||||
- configmap.yaml
|
- configmap.yaml
|
||||||
- deployments.yaml
|
- deployments.yaml
|
||||||
- ingress.yaml
|
- ingress.yaml
|
||||||
- pvc.yaml
|
- pvc.yaml
|
||||||
- secrets.yaml
|
- secrets.yaml
|
||||||
|
- services.yaml
|
||||||
- namespace.yaml
|
- namespace.yaml
|
||||||
|
|
||||||
components:
|
|
||||||
- ../../kustomize-bases/nfs-media/components/downloads
|
|
||||||
|
|
||||||
patches:
|
patches:
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolume
|
kind: PersistentVolume
|
||||||
name: nfs-media-downloads
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /metadata/name
|
path: /metadata/name
|
||||||
value: nfs-media-qbittorrent-downloads
|
value: nfs-media-qbittorrent
|
||||||
|
- op: replace
|
||||||
|
path: /spec/nfs/path
|
||||||
|
value: /tank/media/downloads
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolumeClaim
|
kind: PersistentVolumeClaim
|
||||||
name: nfs-media-downloads
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /spec/volumeName
|
path: /spec/volumeName
|
||||||
value: nfs-media-qbittorrent-downloads
|
value: nfs-media-qbittorrent
|
||||||
|
|
||||||
images:
|
images:
|
||||||
- name: ghcr.io/qdm12/gluetun
|
- name: ghcr.io/qdm12/gluetun
|
||||||
newTag: v3.41.1@sha256:1a5bf4b4820a879cdf8d93d7ef0d2d963af56670c9ebff8981860b6804ebc8ab
|
newTag: v3.41.1@sha256:1a5bf4b4820a879cdf8d93d7ef0d2d963af56670c9ebff8981860b6804ebc8ab
|
||||||
- name: docker.io/qbittorrentofficial/qbittorrent-nox
|
- name: docker.io/qbittorrentofficial/qbittorrent-nox
|
||||||
newTag: 5.1.4-2@sha256:85fe2690f418dabffc4907276b3cdffcb7880c7114157b32f932d3b97bac45af
|
newTag: 5.1.4-2@sha256:85fe2690f418dabffc4907276b3cdffcb7880c7114157b32f932d3b97bac45af
|
||||||
- name: docker.io/slskd/slskd
|
|
||||||
newTag: 0.25.1
|
|
||||||
|
|
|
||||||
|
|
@ -10,15 +10,3 @@ spec:
|
||||||
resources:
|
resources:
|
||||||
requests:
|
requests:
|
||||||
storage: 5Gi
|
storage: 5Gi
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: slskd-storage
|
|
||||||
spec:
|
|
||||||
storageClassName: piraeus-lvmthin
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteOnce
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 1Gi
|
|
||||||
|
|
|
||||||
|
|
@ -17,57 +17,6 @@ spec:
|
||||||
remoteRef:
|
remoteRef:
|
||||||
key: secrets/managed/qbittorrent/protonvpn-wgconfig
|
key: secrets/managed/qbittorrent/protonvpn-wgconfig
|
||||||
property: config
|
property: config
|
||||||
|
|
||||||
---
|
|
||||||
apiVersion: external-secrets.io/v1
|
|
||||||
kind: ExternalSecret
|
|
||||||
metadata:
|
|
||||||
name: slskd-env-secrets
|
|
||||||
spec:
|
|
||||||
secretStoreRef:
|
|
||||||
name: vault-wheatley
|
|
||||||
kind: ClusterSecretStore
|
|
||||||
target:
|
|
||||||
name: slskd-env-secrets
|
|
||||||
data:
|
|
||||||
- secretKey: SLSKD_VPN_GLUETUN_API_KEY
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/qbittorrent/slskd-env-secrets
|
|
||||||
property: GLUETUN_API_KEY
|
|
||||||
- secretKey: SLSKD_SLSK_USERNAME
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/qbittorrent/slskd-env-secrets
|
|
||||||
property: SLSK_USERNAME
|
|
||||||
- secretKey: SLSKD_SLSK_PASSWORD
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/qbittorrent/slskd-env-secrets
|
|
||||||
property: SLSK_PASSWORD
|
|
||||||
- secretKey: SLSKD_PASSWORD
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/qbittorrent/slskd-env-secrets
|
|
||||||
property: SLSKD_PASSWORD
|
|
||||||
- secretKey: SLSKD_API_KEY
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/qbittorrent/slskd-env-secrets
|
|
||||||
property: API_KEY
|
|
||||||
|
|
||||||
---
|
|
||||||
apiVersion: external-secrets.io/v1
|
|
||||||
kind: ExternalSecret
|
|
||||||
metadata:
|
|
||||||
name: gluetun-env-secrets
|
|
||||||
spec:
|
|
||||||
secretStoreRef:
|
|
||||||
name: vault-wheatley
|
|
||||||
kind: ClusterSecretStore
|
|
||||||
target:
|
|
||||||
name: gluetun-env-secrets
|
|
||||||
data:
|
|
||||||
- secretKey: HTTP_CONTROL_SERVER_AUTH_DEFAULT_ROLE
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/qbittorrent/gluetun-env-secrets
|
|
||||||
property: HTTP_CONTROL_SERVER_AUTH_DEFAULT_ROLE
|
|
||||||
|
|
||||||
---
|
---
|
||||||
apiVersion: external-secrets.io/v1
|
apiVersion: external-secrets.io/v1
|
||||||
kind: ExternalSecret
|
kind: ExternalSecret
|
||||||
|
|
|
||||||
|
|
@ -2,11 +2,11 @@
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
name: romm
|
name: qbittorrent
|
||||||
spec:
|
spec:
|
||||||
selector:
|
selector:
|
||||||
app: romm
|
app: qbittorrent
|
||||||
ports:
|
ports:
|
||||||
- port: 80
|
- port: 80
|
||||||
protocol: TCP
|
protocol: TCP
|
||||||
targetPort: 8080
|
targetPort: 8112
|
||||||
|
|
@ -28,10 +28,8 @@ spec:
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- mountPath: /config
|
- mountPath: /config
|
||||||
name: radarr-config
|
name: radarr-config
|
||||||
- mountPath: /shared/media/movies
|
- mountPath: /shared/media
|
||||||
name: nfs-media-movies
|
name: nfs-media
|
||||||
- mountPath: /shared/media/downloads
|
|
||||||
name: nfs-media-downloads
|
|
||||||
securityContext:
|
securityContext:
|
||||||
seccompProfile:
|
seccompProfile:
|
||||||
type: RuntimeDefault
|
type: RuntimeDefault
|
||||||
|
|
@ -47,9 +45,6 @@ spec:
|
||||||
- name: radarr-config
|
- name: radarr-config
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: radarr-storage
|
claimName: radarr-storage
|
||||||
- name: nfs-media-movies
|
- name: nfs-media
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: nfs-media-movies
|
claimName: nfs-media
|
||||||
- name: nfs-media-downloads
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-downloads
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ kind: Kustomization
|
||||||
namespace: radarr
|
namespace: radarr
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
|
- ../../kustomize-bases/nfs-media
|
||||||
- configmap.yaml
|
- configmap.yaml
|
||||||
- deployments.yaml
|
- deployments.yaml
|
||||||
- ingress.yaml
|
- ingress.yaml
|
||||||
|
|
@ -12,39 +13,21 @@ resources:
|
||||||
- services.yaml
|
- services.yaml
|
||||||
- namespace.yaml
|
- namespace.yaml
|
||||||
|
|
||||||
components:
|
|
||||||
- ../../kustomize-bases/nfs-media/components/movies
|
|
||||||
- ../../kustomize-bases/nfs-media/components/downloads
|
|
||||||
|
|
||||||
patches:
|
patches:
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolume
|
kind: PersistentVolume
|
||||||
name: nfs-media-movies
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /metadata/name
|
path: /metadata/name
|
||||||
value: nfs-media-radarr-movies
|
value: nfs-media-radarr
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolumeClaim
|
kind: PersistentVolumeClaim
|
||||||
name: nfs-media-movies
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /spec/volumeName
|
path: /spec/volumeName
|
||||||
value: nfs-media-radarr-movies
|
value: nfs-media-radarr
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-radarr-downloads
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-radarr-downloads
|
|
||||||
|
|
||||||
images:
|
images:
|
||||||
- name: linuxserver/radarr
|
- name: linuxserver/radarr
|
||||||
|
|
|
||||||
|
|
@ -1,21 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: ConfigMap
|
|
||||||
metadata:
|
|
||||||
name: romm-db-envs
|
|
||||||
data:
|
|
||||||
MARIADB_DATABASE: romm
|
|
||||||
MARIADB_USER: romm
|
|
||||||
TZ: Europe/Amsterdam
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: ConfigMap
|
|
||||||
metadata:
|
|
||||||
name: romm-envs
|
|
||||||
data:
|
|
||||||
DB_HOST: 127.0.0.1
|
|
||||||
DB_NAME: romm
|
|
||||||
DB_USER: romm
|
|
||||||
ROMM_PORT: "8080"
|
|
||||||
HASHEOUS_API_ENABLED: "true"
|
|
||||||
TZ: Europe/Amsterdam
|
|
||||||
|
|
@ -1,83 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: apps/v1
|
|
||||||
kind: StatefulSet
|
|
||||||
metadata:
|
|
||||||
name: romm
|
|
||||||
labels:
|
|
||||||
app: romm
|
|
||||||
spec:
|
|
||||||
replicas: 1
|
|
||||||
serviceName: romm
|
|
||||||
selector:
|
|
||||||
matchLabels:
|
|
||||||
app: romm
|
|
||||||
template:
|
|
||||||
metadata:
|
|
||||||
labels:
|
|
||||||
app: romm
|
|
||||||
spec:
|
|
||||||
initContainers:
|
|
||||||
- name: romm-db
|
|
||||||
image: mariadb
|
|
||||||
envFrom:
|
|
||||||
- configMapRef:
|
|
||||||
name: romm-db-envs
|
|
||||||
- secretRef:
|
|
||||||
name: romm-db-env-secrets
|
|
||||||
volumeMounts:
|
|
||||||
- mountPath: /var/lib/mysql
|
|
||||||
name: romm-db-data
|
|
||||||
restartPolicy: Always
|
|
||||||
readinessProbe:
|
|
||||||
exec:
|
|
||||||
command:
|
|
||||||
- sh
|
|
||||||
- -c
|
|
||||||
- "healthcheck.sh --connect --innodb_initialized"
|
|
||||||
initialDelaySeconds: 5
|
|
||||||
periodSeconds: 3
|
|
||||||
timeoutSeconds: 2
|
|
||||||
failureThreshold: 3
|
|
||||||
livenessProbe:
|
|
||||||
exec:
|
|
||||||
command:
|
|
||||||
- sh
|
|
||||||
- -c
|
|
||||||
- "healthcheck.sh --connect --innodb_initialized"
|
|
||||||
initialDelaySeconds: 10
|
|
||||||
periodSeconds: 15
|
|
||||||
timeoutSeconds: 2
|
|
||||||
failureThreshold: 3
|
|
||||||
containers:
|
|
||||||
- name: romm
|
|
||||||
image: rommapp/romm
|
|
||||||
imagePullPolicy: IfNotPresent
|
|
||||||
ports:
|
|
||||||
- containerPort: 8080
|
|
||||||
envFrom:
|
|
||||||
- configMapRef:
|
|
||||||
name: romm-envs
|
|
||||||
- secretRef:
|
|
||||||
name: romm-env-secrets
|
|
||||||
volumeMounts:
|
|
||||||
- mountPath: /romm
|
|
||||||
name: romm-data
|
|
||||||
- mountPath: /romm/library
|
|
||||||
name: nfs-media-roms
|
|
||||||
readOnly: true
|
|
||||||
- mountPath: /romm/downloads
|
|
||||||
name: nfs-media-downloads
|
|
||||||
readOnly: true
|
|
||||||
volumes:
|
|
||||||
- name: romm-db-data
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: romm-db-storage
|
|
||||||
- name: romm-data
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: romm-storage
|
|
||||||
- name: nfs-media-roms
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-roms
|
|
||||||
- name: nfs-media-downloads
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-downloads
|
|
||||||
|
|
@ -1,16 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: gateway.networking.k8s.io/v1
|
|
||||||
kind: HTTPRoute
|
|
||||||
metadata:
|
|
||||||
name: romm-route
|
|
||||||
spec:
|
|
||||||
parentRefs:
|
|
||||||
- name: internal
|
|
||||||
namespace: kube-system
|
|
||||||
sectionName: https
|
|
||||||
hostnames:
|
|
||||||
- "roms.wheatley.in"
|
|
||||||
rules:
|
|
||||||
- backendRefs:
|
|
||||||
- name: romm
|
|
||||||
port: 80
|
|
||||||
|
|
@ -1,53 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1beta1
|
|
||||||
kind: Kustomization
|
|
||||||
namespace: romm
|
|
||||||
|
|
||||||
resources:
|
|
||||||
- configmap.yaml
|
|
||||||
- deployments.yaml
|
|
||||||
- ingress.yaml
|
|
||||||
- pvc.yaml
|
|
||||||
- secrets.yaml
|
|
||||||
- services.yaml
|
|
||||||
- namespace.yaml
|
|
||||||
|
|
||||||
components:
|
|
||||||
- ../../kustomize-bases/nfs-media/components/roms
|
|
||||||
- ../../kustomize-bases/nfs-media/components/downloads
|
|
||||||
|
|
||||||
patches:
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-roms
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-romm-roms
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-romm-downloads
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-roms
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-romm-roms
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-romm-downloads
|
|
||||||
|
|
||||||
images:
|
|
||||||
- name: mariadb
|
|
||||||
newTag: lts
|
|
||||||
- name: rommapp/romm
|
|
||||||
newTag: 4.8.1
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Namespace
|
|
||||||
metadata:
|
|
||||||
name: romm
|
|
||||||
|
|
@ -1,24 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: romm-db-storage
|
|
||||||
spec:
|
|
||||||
storageClassName: piraeus-lvmthin
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteOnce
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 5Gi
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: romm-storage
|
|
||||||
spec:
|
|
||||||
storageClassName: piraeus-lvmthin
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteOnce
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 10Gi
|
|
||||||
|
|
@ -1,52 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: external-secrets.io/v1
|
|
||||||
kind: ExternalSecret
|
|
||||||
metadata:
|
|
||||||
name: romm-db-env-secrets
|
|
||||||
spec:
|
|
||||||
secretStoreRef:
|
|
||||||
name: vault-wheatley
|
|
||||||
kind: ClusterSecretStore
|
|
||||||
target:
|
|
||||||
name: romm-db-env-secrets
|
|
||||||
data:
|
|
||||||
- secretKey: MARIADB_ROOT_PASSWORD
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/romm/romm-db
|
|
||||||
property: ROOT_PASSWORD
|
|
||||||
- secretKey: MARIADB_PASSWORD
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/romm/romm-db
|
|
||||||
property: PASSWORD
|
|
||||||
---
|
|
||||||
apiVersion: external-secrets.io/v1
|
|
||||||
kind: ExternalSecret
|
|
||||||
metadata:
|
|
||||||
name: romm-env-secrets
|
|
||||||
spec:
|
|
||||||
secretStoreRef:
|
|
||||||
name: vault-wheatley
|
|
||||||
kind: ClusterSecretStore
|
|
||||||
target:
|
|
||||||
name: romm-env-secrets
|
|
||||||
data:
|
|
||||||
- secretKey: DB_PASSWD
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/romm/romm-db
|
|
||||||
property: PASSWORD
|
|
||||||
- secretKey: ROMM_AUTH_SECRET_KEY
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/romm/romm
|
|
||||||
property: SECRET_KEY
|
|
||||||
- secretKey: IGDB_CLIENT_ID
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/romm/romm
|
|
||||||
property: IGDB_CLIENT_ID
|
|
||||||
- secretKey: IGDB_CLIENT_SECRET
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/romm/romm
|
|
||||||
property: IGDB_CLIENT_SECRET
|
|
||||||
- secretKey: STEAMGRIDDB_API_KEY
|
|
||||||
remoteRef:
|
|
||||||
key: secrets/managed/romm/romm
|
|
||||||
property: STEAMGRIDDB_API_KEY
|
|
||||||
|
|
@ -28,12 +28,8 @@ spec:
|
||||||
volumeMounts:
|
volumeMounts:
|
||||||
- mountPath: /config
|
- mountPath: /config
|
||||||
name: sonarr-config
|
name: sonarr-config
|
||||||
- mountPath: /shared/media/series
|
- mountPath: /shared/media
|
||||||
name: nfs-media-series
|
name: nfs-media
|
||||||
- mountPath: /shared/media/anime
|
|
||||||
name: nfs-media-anime
|
|
||||||
- mountPath: /shared/media/downloads
|
|
||||||
name: nfs-media-downloads
|
|
||||||
securityContext:
|
securityContext:
|
||||||
seccompProfile:
|
seccompProfile:
|
||||||
type: RuntimeDefault
|
type: RuntimeDefault
|
||||||
|
|
@ -49,12 +45,6 @@ spec:
|
||||||
- name: sonarr-config
|
- name: sonarr-config
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: sonarr-storage
|
claimName: sonarr-storage
|
||||||
- name: nfs-media-series
|
- name: nfs-media
|
||||||
persistentVolumeClaim:
|
persistentVolumeClaim:
|
||||||
claimName: nfs-media-series
|
claimName: nfs-media
|
||||||
- name: nfs-media-anime
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-anime
|
|
||||||
- name: nfs-media-downloads
|
|
||||||
persistentVolumeClaim:
|
|
||||||
claimName: nfs-media-downloads
|
|
||||||
|
|
|
||||||
|
|
@ -4,6 +4,7 @@ kind: Kustomization
|
||||||
namespace: sonarr
|
namespace: sonarr
|
||||||
|
|
||||||
resources:
|
resources:
|
||||||
|
- ../../kustomize-bases/nfs-media
|
||||||
- configmap.yaml
|
- configmap.yaml
|
||||||
- deployments.yaml
|
- deployments.yaml
|
||||||
- ingress.yaml
|
- ingress.yaml
|
||||||
|
|
@ -12,54 +13,21 @@ resources:
|
||||||
- services.yaml
|
- services.yaml
|
||||||
- namespace.yaml
|
- namespace.yaml
|
||||||
|
|
||||||
components:
|
|
||||||
- ../../kustomize-bases/nfs-media/components/series
|
|
||||||
- ../../kustomize-bases/nfs-media/components/anime
|
|
||||||
- ../../kustomize-bases/nfs-media/components/downloads
|
|
||||||
|
|
||||||
patches:
|
patches:
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolume
|
kind: PersistentVolume
|
||||||
name: nfs-media-series
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /metadata/name
|
path: /metadata/name
|
||||||
value: nfs-media-sonarr-series
|
value: nfs-media-sonarr
|
||||||
- target:
|
- target:
|
||||||
kind: PersistentVolumeClaim
|
kind: PersistentVolumeClaim
|
||||||
name: nfs-media-series
|
name: nfs-media
|
||||||
patch: |
|
patch: |
|
||||||
- op: replace
|
- op: replace
|
||||||
path: /spec/volumeName
|
path: /spec/volumeName
|
||||||
value: nfs-media-sonarr-series
|
value: nfs-media-sonarr
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-anime
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-sonarr-anime
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-anime
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-sonarr-anime
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolume
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /metadata/name
|
|
||||||
value: nfs-media-sonarr-downloads
|
|
||||||
- target:
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
name: nfs-media-downloads
|
|
||||||
patch: |
|
|
||||||
- op: replace
|
|
||||||
path: /spec/volumeName
|
|
||||||
value: nfs-media-sonarr-downloads
|
|
||||||
|
|
||||||
images:
|
images:
|
||||||
- name: linuxserver/sonarr
|
- name: linuxserver/sonarr
|
||||||
|
|
|
||||||
|
|
@ -9,4 +9,4 @@ spec:
|
||||||
- ReadWriteOnce
|
- ReadWriteOnce
|
||||||
resources:
|
resources:
|
||||||
requests:
|
requests:
|
||||||
storage: 10Gi
|
storage: 5Gi
|
||||||
|
|
|
||||||
|
|
@ -13,5 +13,5 @@ helmCharts:
|
||||||
repo: https://helm.cilium.io
|
repo: https://helm.cilium.io
|
||||||
namespace: kube-system
|
namespace: kube-system
|
||||||
releaseName: cilium
|
releaseName: cilium
|
||||||
version: 1.18.10
|
version: 1.18.6
|
||||||
valuesFile: values.yaml
|
valuesFile: values.yaml
|
||||||
|
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1alpha1
|
|
||||||
kind: Component
|
|
||||||
resources:
|
|
||||||
- pvc.yaml
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolume
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-anime
|
|
||||||
spec:
|
|
||||||
capacity:
|
|
||||||
storage: 40Ti
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
nfs:
|
|
||||||
server: 10.0.69.10
|
|
||||||
path: /tank/media/anime
|
|
||||||
mountOptions:
|
|
||||||
- vers=4.1
|
|
||||||
- rsize=1048576
|
|
||||||
- wsize=1048576
|
|
||||||
- hard
|
|
||||||
- timeo=600
|
|
||||||
- noatime
|
|
||||||
persistentVolumeReclaimPolicy: Retain
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-anime
|
|
||||||
spec:
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 40Ti
|
|
||||||
volumeName: nfs-media-anime
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1alpha1
|
|
||||||
kind: Component
|
|
||||||
resources:
|
|
||||||
- pvc.yaml
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolume
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-downloads
|
|
||||||
spec:
|
|
||||||
capacity:
|
|
||||||
storage: 40Ti
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
nfs:
|
|
||||||
server: 10.0.69.10
|
|
||||||
path: /tank/media/downloads
|
|
||||||
mountOptions:
|
|
||||||
- vers=4.1
|
|
||||||
- rsize=1048576
|
|
||||||
- wsize=1048576
|
|
||||||
- hard
|
|
||||||
- timeo=600
|
|
||||||
- noatime
|
|
||||||
persistentVolumeReclaimPolicy: Retain
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-downloads
|
|
||||||
spec:
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 40Ti
|
|
||||||
volumeName: nfs-media-downloads
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1alpha1
|
|
||||||
kind: Component
|
|
||||||
resources:
|
|
||||||
- pvc.yaml
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolume
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-movies
|
|
||||||
spec:
|
|
||||||
capacity:
|
|
||||||
storage: 40Ti
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
nfs:
|
|
||||||
server: 10.0.69.10
|
|
||||||
path: /tank/media/movies
|
|
||||||
mountOptions:
|
|
||||||
- vers=4.1
|
|
||||||
- rsize=1048576
|
|
||||||
- wsize=1048576
|
|
||||||
- hard
|
|
||||||
- timeo=600
|
|
||||||
- noatime
|
|
||||||
persistentVolumeReclaimPolicy: Retain
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-movies
|
|
||||||
spec:
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 40Ti
|
|
||||||
volumeName: nfs-media-movies
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1alpha1
|
|
||||||
kind: Component
|
|
||||||
resources:
|
|
||||||
- pvc.yaml
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolume
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-music
|
|
||||||
spec:
|
|
||||||
capacity:
|
|
||||||
storage: 40Ti
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
nfs:
|
|
||||||
server: 10.0.69.10
|
|
||||||
path: /tank/media/music
|
|
||||||
mountOptions:
|
|
||||||
- vers=4.1
|
|
||||||
- rsize=1048576
|
|
||||||
- wsize=1048576
|
|
||||||
- hard
|
|
||||||
- timeo=600
|
|
||||||
- noatime
|
|
||||||
persistentVolumeReclaimPolicy: Retain
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-music
|
|
||||||
spec:
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 40Ti
|
|
||||||
volumeName: nfs-media-music
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1alpha1
|
|
||||||
kind: Component
|
|
||||||
resources:
|
|
||||||
- pvc.yaml
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolume
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-roms
|
|
||||||
spec:
|
|
||||||
capacity:
|
|
||||||
storage: 40Ti
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
nfs:
|
|
||||||
server: 10.0.69.10
|
|
||||||
path: /tank/media/roms
|
|
||||||
mountOptions:
|
|
||||||
- vers=4.1
|
|
||||||
- rsize=1048576
|
|
||||||
- wsize=1048576
|
|
||||||
- hard
|
|
||||||
- timeo=600
|
|
||||||
- noatime
|
|
||||||
persistentVolumeReclaimPolicy: Retain
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-roms
|
|
||||||
spec:
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 40Ti
|
|
||||||
volumeName: nfs-media-roms
|
|
||||||
|
|
@ -1,5 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: kustomize.config.k8s.io/v1alpha1
|
|
||||||
kind: Component
|
|
||||||
resources:
|
|
||||||
- pvc.yaml
|
|
||||||
|
|
@ -1,33 +0,0 @@
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolume
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-series
|
|
||||||
spec:
|
|
||||||
capacity:
|
|
||||||
storage: 40Ti
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
nfs:
|
|
||||||
server: 10.0.69.10
|
|
||||||
path: /tank/media/series
|
|
||||||
mountOptions:
|
|
||||||
- vers=4.1
|
|
||||||
- rsize=1048576
|
|
||||||
- wsize=1048576
|
|
||||||
- hard
|
|
||||||
- timeo=600
|
|
||||||
- noatime
|
|
||||||
persistentVolumeReclaimPolicy: Retain
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: PersistentVolumeClaim
|
|
||||||
metadata:
|
|
||||||
name: nfs-media-series
|
|
||||||
spec:
|
|
||||||
accessModes:
|
|
||||||
- ReadWriteMany
|
|
||||||
resources:
|
|
||||||
requests:
|
|
||||||
storage: 40Ti
|
|
||||||
volumeName: nfs-media-series
|
|
||||||
6
kustomize-bases/nfs-media/kustomization.yaml
Normal file
6
kustomize-bases/nfs-media/kustomization.yaml
Normal file
|
|
@ -0,0 +1,6 @@
|
||||||
|
---
|
||||||
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
|
kind: Kustomization
|
||||||
|
|
||||||
|
resources:
|
||||||
|
- pvc.yaml
|
||||||
40
kustomize-bases/nfs-media/pvc.yaml
Normal file
40
kustomize-bases/nfs-media/pvc.yaml
Normal file
|
|
@ -0,0 +1,40 @@
|
||||||
|
# Shared NFS media storage template — used by plex, sonarr, radarr, and qbittorrent.
|
||||||
|
# All apps on k8s-wheatley mount the same NFS server: 10.0.69.10
|
||||||
|
#
|
||||||
|
# Each app overlays this base with JSON patches in its kustomization.yaml:
|
||||||
|
# - Always: rename PV (metadata.name) and update PVC volumeName to match
|
||||||
|
# - plex only: patch accessModes to ReadOnlyMany on both PV and PVC
|
||||||
|
# - qbittorrent only: patch nfs.path to /tank/media/downloads
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolume
|
||||||
|
metadata:
|
||||||
|
name: nfs-media # renamed per-app via JSON patch
|
||||||
|
spec:
|
||||||
|
capacity:
|
||||||
|
storage: 40Ti
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteMany
|
||||||
|
nfs:
|
||||||
|
server: 10.0.69.10
|
||||||
|
path: /tank/media
|
||||||
|
mountOptions:
|
||||||
|
- vers=4.1
|
||||||
|
- rsize=1048576
|
||||||
|
- wsize=1048576
|
||||||
|
- hard
|
||||||
|
- timeo=600
|
||||||
|
- noatime
|
||||||
|
persistentVolumeReclaimPolicy: Retain
|
||||||
|
---
|
||||||
|
apiVersion: v1
|
||||||
|
kind: PersistentVolumeClaim
|
||||||
|
metadata:
|
||||||
|
name: nfs-media
|
||||||
|
spec:
|
||||||
|
accessModes:
|
||||||
|
- ReadWriteMany
|
||||||
|
resources:
|
||||||
|
requests:
|
||||||
|
storage: 40Ti
|
||||||
|
volumeName: nfs-media # patched per-app to match PV name
|
||||||
Loading…
Add table
Add a link
Reference in a new issue