mirror of
https://github.com/optim-enterprises-bv/homelab.git
synced 2025-10-31 18:07:50 +00:00
feat(apps): Starting to use Terraform and adding applications
This commit is contained in:
@@ -39,13 +39,13 @@ cilium install
|
|||||||
https://raw.githubusercontent.com/metallb/metallb/v0.13.5/config/manifests/metallb-native.yaml
|
https://raw.githubusercontent.com/metallb/metallb/v0.13.5/config/manifests/metallb-native.yaml
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
kubectl apply -f metallb/00-manifest.yml
|
kubectl apply -f infra/metallb/00-manifest.yml
|
||||||
```
|
```
|
||||||
|
|
||||||
## Configure MetalLB
|
## Configure MetalLB
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
kubectl apply -f metallb/01-configuration.yml
|
kubectl apply -f infra/metallb/01-configuration.yml
|
||||||
```
|
```
|
||||||
|
|
||||||
# Traefik
|
# Traefik
|
||||||
@@ -64,8 +64,10 @@ terraform plan
|
|||||||
terraform apply
|
terraform apply
|
||||||
```
|
```
|
||||||
|
|
||||||
## Create test application "whoami" with IngressRoutes
|
## Test application
|
||||||
|
|
||||||
|
If not already created with Terraform run
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
kubectl apply -f whoami/00-whoami.yml
|
kubectl apply -f apps/whoami/00-whoami.yml
|
||||||
```
|
```
|
||||||
64
README.md
64
README.md
@@ -82,6 +82,7 @@ Install Cilium
|
|||||||
cilium install
|
cilium install
|
||||||
```
|
```
|
||||||
|
|
||||||
|
// TODO: Directly by Helm chart
|
||||||
```shell
|
```shell
|
||||||
helm template --namespace kube-system cilium cilium/cilium --version 1.12.1 --set cluster.id=0,cluster.name=kubernetes,encryption.nodeEncryption=false,kubeProxyReplacement=disabled,operator.replicas=1,serviceAccounts.cilium.name=cilium,serviceAccounts.operator.name=cilium-operator,tunnel=vxlan
|
helm template --namespace kube-system cilium cilium/cilium --version 1.12.1 --set cluster.id=0,cluster.name=kubernetes,encryption.nodeEncryption=false,kubeProxyReplacement=disabled,operator.replicas=1,serviceAccounts.cilium.name=cilium,serviceAccounts.operator.name=cilium-operator,tunnel=vxlan
|
||||||
```
|
```
|
||||||
@@ -112,74 +113,43 @@ Installation
|
|||||||
https://raw.githubusercontent.com/metallb/metallb/v0.13.5/config/manifests/metallb-native.yaml
|
https://raw.githubusercontent.com/metallb/metallb/v0.13.5/config/manifests/metallb-native.yaml
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
kubectl apply -f metallb/00-manifest.yml
|
kubectl apply -f infra/metallb/00-manifest.yml
|
||||||
```
|
```
|
||||||
|
|
||||||
Configure IP-pool and advertise as Level 2
|
Configure IP-pool and advertise as Level 2
|
||||||
https://metallb.universe.tf/configuration/
|
https://metallb.universe.tf/configuration/
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
kubectl apply -f metallb/01-configuration.yml
|
kubectl apply -f infra/metallb/01-configuration.yml
|
||||||
```
|
```
|
||||||
|
|
||||||
# Traefik
|
# Traefik
|
||||||
|
|
||||||
## Install using Helm
|
## Install using Terraform and Helm
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
kubectl apply -f volumes/volumes.yml
|
terraform init
|
||||||
|
terraform plan
|
||||||
|
terraform apply
|
||||||
```
|
```
|
||||||
|
|
||||||
**NB:** It appears we need the "volume-permissions" init container for Traefik if using `StorageClass` with
|
**NB:** It appears we need the "volume-permissions" init container for Traefik if using `StorageClass` with
|
||||||
provisioner `kubernetes.io/no-provisioner`
|
provisioner `kubernetes.io/no-provisioner`
|
||||||
|
|
||||||
```shell
|
|
||||||
helm install --values=helm/traefik-values.yaml traefik traefik/traefik
|
|
||||||
```
|
|
||||||
|
|
||||||
## Traefik IngressRoute Custom Resource Definition (CRD)
|
|
||||||
|
|
||||||
https://doc.traefik.io/traefik/v2.8/routing/providers/kubernetes-crd/
|
|
||||||
https://doc.traefik.io/traefik/v2.8/user-guides/crd-acme/
|
|
||||||
|
|
||||||
Create Custom Resource Definitions for Traefik
|
|
||||||
|
|
||||||
```shell
|
|
||||||
kubectl apply -f traefik/00-crd-definition.yml
|
|
||||||
kubectl apply -f traefik/01-crd-rbac.yml
|
|
||||||
```
|
|
||||||
|
|
||||||
## Service
|
|
||||||
|
|
||||||
Create service for exposing Traefik deployment
|
|
||||||
|
|
||||||
```shell
|
|
||||||
kubectl apply -f traefik/02-service.yml
|
|
||||||
```
|
|
||||||
|
|
||||||
## Deployment
|
|
||||||
|
|
||||||
Create deployment for Traefik
|
|
||||||
|
|
||||||
```shell
|
|
||||||
kubectl apply -f traefik/03-deployment.yml
|
|
||||||
```
|
|
||||||
|
|
||||||
## Port forward Traefik
|
## Port forward Traefik
|
||||||
|
|
||||||
Port forward Traefik ports from 8000 to 80 for http and 4443 to 443 for https.
|
Port forward Traefik ports in router from 8000 to 80 for http and 4443 to 443 for https.
|
||||||
IP can be found with `kubectl get svc`.
|
IP can be found with `kubectl get svc`.
|
||||||
|
|
||||||
# Test-application
|
# Test-application
|
||||||
|
|
||||||
Create a test-application with
|
Create a test-application (if not already created with Terraform) with
|
||||||
|
|
||||||
```shell
|
```shell
|
||||||
kubectl apply -f whoami/00-whoami.yml
|
kubectl apply -f apps/whoami/00-whoami.yml
|
||||||
```
|
```
|
||||||
|
|
||||||
`whoami` should now be available using https at `https://test.ratatoskr.myddns.rocks/tls`
|
`whoami` should now be available at `https://whoami.${DOMAIN}`.
|
||||||
and using http at `http://test.ratatoskr.myddns.rocks/notls`.
|
|
||||||
|
|
||||||
# Cleanup
|
# Cleanup
|
||||||
|
|
||||||
@@ -189,15 +159,3 @@ sudo kubeadm reset
|
|||||||
sudo iptables -F && sudo iptables -t nat -F && sudo iptables -t mangle -F && sudo iptables -X
|
sudo iptables -F && sudo iptables -t nat -F && sudo iptables -t mangle -F && sudo iptables -X
|
||||||
sudo ipvsadm -C
|
sudo ipvsadm -C
|
||||||
```
|
```
|
||||||
|
|
||||||
# TODO
|
|
||||||
|
|
||||||
## Deploy using Terraform
|
|
||||||
|
|
||||||
https://registry.terraform.io/providers/hashicorp/kubernetes/latest/docs/guides/getting-started
|
|
||||||
|
|
||||||
```shell
|
|
||||||
terraform plan
|
|
||||||
terraform apply
|
|
||||||
```
|
|
||||||
|
|
||||||
|
|||||||
404
apps/arr/00-arr.yaml
Normal file
404
apps/arr/00-arr.yaml
Normal file
@@ -0,0 +1,404 @@
|
|||||||
|
---
|
||||||
|
## Namespace
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Namespace
|
||||||
|
metadata:
|
||||||
|
name: arr
|
||||||
|
labels:
|
||||||
|
name: arr
|
||||||
|
---
|
||||||
|
# Qbittorrent
|
||||||
|
---
|
||||||
|
## Service for exposing Qbittorrent
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: qbittorrent
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
port: 8112
|
||||||
|
- name: a
|
||||||
|
port: 11010
|
||||||
|
protocol: TCP
|
||||||
|
- name: b
|
||||||
|
port: 11011
|
||||||
|
protocol: TCP
|
||||||
|
- name: c
|
||||||
|
port: 11012
|
||||||
|
protocol: TCP
|
||||||
|
- name: d
|
||||||
|
port: 11013
|
||||||
|
protocol: TCP
|
||||||
|
- name: e
|
||||||
|
port: 11014
|
||||||
|
protocol: TCP
|
||||||
|
- name: f
|
||||||
|
port: 11015
|
||||||
|
protocol: TCP
|
||||||
|
- name: a1
|
||||||
|
port: 11010
|
||||||
|
protocol: UDP
|
||||||
|
- name: b1
|
||||||
|
port: 11011
|
||||||
|
protocol: UDP
|
||||||
|
- name: c1
|
||||||
|
port: 11012
|
||||||
|
protocol: UDP
|
||||||
|
- name: d1
|
||||||
|
port: 11013
|
||||||
|
protocol: UDP
|
||||||
|
- name: e1
|
||||||
|
port: 11014
|
||||||
|
protocol: UDP
|
||||||
|
- name: f1
|
||||||
|
port: 11015
|
||||||
|
protocol: UDP
|
||||||
|
selector:
|
||||||
|
app: qbittorrent
|
||||||
|
---
|
||||||
|
## Deployment for Sonarr
|
||||||
|
kind: Deployment
|
||||||
|
apiVersion: apps/v1
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: qbittorrent
|
||||||
|
labels:
|
||||||
|
app: qbittorrent
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: qbittorrent
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: qbittorrent
|
||||||
|
spec:
|
||||||
|
volumes:
|
||||||
|
- name: qbittorrent-config
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/homelab/config/qbittorrent"
|
||||||
|
- name: media-data
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/data"
|
||||||
|
containers:
|
||||||
|
- name: qbittorrent
|
||||||
|
image: lscr.io/linuxserver/qbittorrent:14.3.9.99202110311443-7435-01519b5e7ubuntu20.04.1-ls166
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/config"
|
||||||
|
name: qbittorrent-config
|
||||||
|
- mountPath: "/app/data"
|
||||||
|
name: media-data
|
||||||
|
env:
|
||||||
|
- name: PUID
|
||||||
|
value: "1000"
|
||||||
|
- name: PGID
|
||||||
|
value: "1000"
|
||||||
|
- name: TZ
|
||||||
|
value: Europe/Oslo
|
||||||
|
- name: WEBUI_PORT
|
||||||
|
value: "8112"
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
containerPort: 8112
|
||||||
|
- containerPort: 11010
|
||||||
|
protocol: TCP
|
||||||
|
- containerPort: 11011
|
||||||
|
protocol: TCP
|
||||||
|
- containerPort: 11012
|
||||||
|
protocol: TCP
|
||||||
|
- containerPort: 11013
|
||||||
|
protocol: TCP
|
||||||
|
- containerPort: 11014
|
||||||
|
protocol: TCP
|
||||||
|
- containerPort: 11015
|
||||||
|
protocol: TCP
|
||||||
|
- containerPort: 11010
|
||||||
|
protocol: UDP
|
||||||
|
- containerPort: 11011
|
||||||
|
protocol: UDP
|
||||||
|
- containerPort: 11012
|
||||||
|
protocol: UDP
|
||||||
|
- containerPort: 11013
|
||||||
|
protocol: UDP
|
||||||
|
- containerPort: 11014
|
||||||
|
protocol: UDP
|
||||||
|
- containerPort: 11015
|
||||||
|
protocol: UDP
|
||||||
|
---
|
||||||
|
# Prowlarr
|
||||||
|
---
|
||||||
|
## Service for exposing Prowlarr
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: prowlarr
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
port: 9696
|
||||||
|
selector:
|
||||||
|
app: prowlarr
|
||||||
|
---
|
||||||
|
## Deployment for Prowlarr
|
||||||
|
kind: Deployment
|
||||||
|
apiVersion: apps/v1
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: prowlarr
|
||||||
|
labels:
|
||||||
|
app: prowlarr
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: prowlarr
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: prowlarr
|
||||||
|
spec:
|
||||||
|
volumes:
|
||||||
|
- name: prowlarr-config
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/homelab/config/prowlarr"
|
||||||
|
containers:
|
||||||
|
- name: prowlarr
|
||||||
|
image: lscr.io/linuxserver/prowlarr:develop
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/config"
|
||||||
|
name: prowlarr-config
|
||||||
|
env:
|
||||||
|
- name: PUID
|
||||||
|
value: "1000"
|
||||||
|
- name: PGID
|
||||||
|
value: "1000"
|
||||||
|
- name: TZ
|
||||||
|
value: Europe/Oslo
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
containerPort: 9696
|
||||||
|
---
|
||||||
|
# Sonarr
|
||||||
|
---
|
||||||
|
## Service for exposing Sonarr
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: sonarr
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
port: 8989
|
||||||
|
selector:
|
||||||
|
app: sonarr
|
||||||
|
---
|
||||||
|
## Deployment for Sonarr
|
||||||
|
kind: Deployment
|
||||||
|
apiVersion: apps/v1
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: sonarr
|
||||||
|
labels:
|
||||||
|
app: sonarr
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: sonarr
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: sonarr
|
||||||
|
spec:
|
||||||
|
volumes:
|
||||||
|
- name: sonarr-config
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/homelab/config/sonarr"
|
||||||
|
- name: media-data
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/data"
|
||||||
|
containers:
|
||||||
|
- name: sonarr
|
||||||
|
image: lscr.io/linuxserver/sonarr
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/config"
|
||||||
|
name: sonarr-config
|
||||||
|
- mountPath: "/app/data"
|
||||||
|
name: media-data
|
||||||
|
env:
|
||||||
|
- name: PUID
|
||||||
|
value: "1000"
|
||||||
|
- name: PGID
|
||||||
|
value: "1000"
|
||||||
|
- name: TZ
|
||||||
|
value: Europe/Oslo
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
containerPort: 8989
|
||||||
|
---
|
||||||
|
# Radarr
|
||||||
|
---
|
||||||
|
## Service for exposing Radarr
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: radarr
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
port: 7878
|
||||||
|
selector:
|
||||||
|
app: radarr
|
||||||
|
---
|
||||||
|
## Deployment for Radarr
|
||||||
|
kind: Deployment
|
||||||
|
apiVersion: apps/v1
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: radarr
|
||||||
|
labels:
|
||||||
|
app: radarr
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: radarr
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: radarr
|
||||||
|
spec:
|
||||||
|
volumes:
|
||||||
|
- name: radarr-config
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/homelab/config/radarr"
|
||||||
|
- name: media-data
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/data"
|
||||||
|
containers:
|
||||||
|
- name: radarr
|
||||||
|
image: lscr.io/linuxserver/radarr
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/config"
|
||||||
|
name: radarr-config
|
||||||
|
- mountPath: "/app/data"
|
||||||
|
name: media-data
|
||||||
|
env:
|
||||||
|
- name: PUID
|
||||||
|
value: "1000"
|
||||||
|
- name: PGID
|
||||||
|
value: "1000"
|
||||||
|
- name: TZ
|
||||||
|
value: Europe/Oslo
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
containerPort: 7878
|
||||||
|
---
|
||||||
|
# Lidarr
|
||||||
|
---
|
||||||
|
## Service for exposing Lidarr
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: lidarr
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
port: 8686
|
||||||
|
selector:
|
||||||
|
app: lidarr
|
||||||
|
---
|
||||||
|
## Deployment for Lidarr
|
||||||
|
kind: Deployment
|
||||||
|
apiVersion: apps/v1
|
||||||
|
metadata:
|
||||||
|
namespace: arr
|
||||||
|
name: lidarr
|
||||||
|
labels:
|
||||||
|
app: lidarr
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: lidarr
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: lidarr
|
||||||
|
spec:
|
||||||
|
volumes:
|
||||||
|
- name: lidarr-config
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/homelab/config/lidarr"
|
||||||
|
- name: media-data
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/data"
|
||||||
|
containers:
|
||||||
|
- name: lidarr
|
||||||
|
image: lscr.io/linuxserver/lidarr
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/config"
|
||||||
|
name: lidarr-config
|
||||||
|
- mountPath: "/app/data"
|
||||||
|
name: media-data
|
||||||
|
env:
|
||||||
|
- name: PUID
|
||||||
|
value: "1000"
|
||||||
|
- name: PGID
|
||||||
|
value: "1000"
|
||||||
|
- name: TZ
|
||||||
|
value: Europe/Oslo
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
containerPort: 8686
|
||||||
|
---
|
||||||
|
## IngressRoute
|
||||||
|
---
|
||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: ingressroute-arr
|
||||||
|
namespace: arr
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
routes:
|
||||||
|
- match: Host(`torrent.stonegarden.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: qbittorrent
|
||||||
|
port: 8112
|
||||||
|
- match: Host(`prowlarr.stonegarden.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: prowlarr
|
||||||
|
port: 9696
|
||||||
|
- match: Host(`sonarr.stonegarden.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: sonarr
|
||||||
|
port: 8989
|
||||||
|
- match: Host(`radarr.stonegarden.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: radarr
|
||||||
|
port: 7878
|
||||||
|
- match: Host(`lidarr.stonegarden.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: lidarr
|
||||||
|
port: 8686
|
||||||
|
tls:
|
||||||
|
certResolver: letsencrypt
|
||||||
227
apps/plex/00-plex.yaml
Normal file
227
apps/plex/00-plex.yaml
Normal file
@@ -0,0 +1,227 @@
|
|||||||
|
---
|
||||||
|
## Namespace
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Namespace
|
||||||
|
metadata:
|
||||||
|
name: plex
|
||||||
|
labels:
|
||||||
|
name: plex
|
||||||
|
|
||||||
|
---
|
||||||
|
### StorageClass for config
|
||||||
|
#apiVersion: storage.k8s.io/v1
|
||||||
|
#kind: StorageClass
|
||||||
|
#metadata:
|
||||||
|
# name: plex-config
|
||||||
|
#provisioner: kubernetes.io/no-provisioner
|
||||||
|
#volumeBindingMode: WaitForFirstConsumer
|
||||||
|
#---
|
||||||
|
### Config
|
||||||
|
#apiVersion: v1
|
||||||
|
#kind: PersistentVolume
|
||||||
|
#metadata:
|
||||||
|
# name: plex-config-pv
|
||||||
|
#spec:
|
||||||
|
# capacity:
|
||||||
|
# storage: 2Gi
|
||||||
|
# volumeMode: Filesystem
|
||||||
|
# accessModes:
|
||||||
|
# - ReadWriteOnce
|
||||||
|
# persistentVolumeReclaimPolicy: Retain
|
||||||
|
# storageClassName: plex-config
|
||||||
|
# local:
|
||||||
|
# path: "/mnt/sdb1/homelab/config/plex"
|
||||||
|
# nodeAffinity:
|
||||||
|
# required:
|
||||||
|
# nodeSelectorTerms:
|
||||||
|
# - matchExpressions:
|
||||||
|
# - key: kubernetes.io/hostname
|
||||||
|
# operator: In
|
||||||
|
# values:
|
||||||
|
# - ratatoskr
|
||||||
|
#---
|
||||||
|
### Persistent Volume Claim for config
|
||||||
|
#apiVersion: v1
|
||||||
|
#kind: PersistentVolumeClaim
|
||||||
|
#metadata:
|
||||||
|
# name: plex-config
|
||||||
|
#spec:
|
||||||
|
# storageClassName: plex-config
|
||||||
|
# accessModes:
|
||||||
|
# - ReadWriteOnce
|
||||||
|
# resources:
|
||||||
|
# requests:
|
||||||
|
# storage: 2Gi
|
||||||
|
#---
|
||||||
|
### StorageClass for media-data
|
||||||
|
#apiVersion: storage.k8s.io/v1
|
||||||
|
#kind: StorageClass
|
||||||
|
#metadata:
|
||||||
|
# name: media-data
|
||||||
|
#provisioner: kubernetes.io/no-provisioner
|
||||||
|
#volumeBindingMode: WaitForFirstConsumer
|
||||||
|
#---
|
||||||
|
### PersistentVolume for media-data
|
||||||
|
#apiVersion: v1
|
||||||
|
#kind: PersistentVolume
|
||||||
|
#metadata:
|
||||||
|
# name: media-data-pv
|
||||||
|
#spec:
|
||||||
|
# capacity:
|
||||||
|
# storage: 1.8Ti
|
||||||
|
# volumeMode: Filesystem
|
||||||
|
# accessModes:
|
||||||
|
# - ReadWriteOnce
|
||||||
|
# persistentVolumeReclaimPolicy: Retain
|
||||||
|
# storageClassName: media-data
|
||||||
|
# local:
|
||||||
|
# path: "/mnt/sdb1/data"
|
||||||
|
# nodeAffinity:
|
||||||
|
# required:
|
||||||
|
# nodeSelectorTerms:
|
||||||
|
# - matchExpressions:
|
||||||
|
# - key: kubernetes.io/hostname
|
||||||
|
# operator: In
|
||||||
|
# values:
|
||||||
|
# - ratatoskr
|
||||||
|
#---
|
||||||
|
### Persistent Volume Claim for media-data
|
||||||
|
#apiVersion: v1
|
||||||
|
#kind: PersistentVolumeClaim
|
||||||
|
#metadata:
|
||||||
|
# name: media-data
|
||||||
|
#spec:
|
||||||
|
# storageClassName: media-data
|
||||||
|
# accessModes:
|
||||||
|
# - ReadWriteOnce
|
||||||
|
# resources:
|
||||||
|
# requests:
|
||||||
|
# storage: 1.8Ti
|
||||||
|
---
|
||||||
|
## Service for exposing Plex
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
namespace: plex
|
||||||
|
name: plex
|
||||||
|
spec:
|
||||||
|
type: LoadBalancer
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
port: 32400
|
||||||
|
- name: a
|
||||||
|
port: 1900
|
||||||
|
protocol: UDP
|
||||||
|
- name: b
|
||||||
|
port: 3005
|
||||||
|
- name: c
|
||||||
|
port: 8324
|
||||||
|
- name: d
|
||||||
|
port: 32410
|
||||||
|
protocol: UDP
|
||||||
|
- name: e
|
||||||
|
port: 32412
|
||||||
|
protocol: UDP
|
||||||
|
- name: f
|
||||||
|
port: 32413
|
||||||
|
protocol: UDP
|
||||||
|
- name: g
|
||||||
|
port: 32414
|
||||||
|
protocol: UDP
|
||||||
|
- name: h
|
||||||
|
port: 32469
|
||||||
|
selector:
|
||||||
|
app: plex
|
||||||
|
---
|
||||||
|
## Deployment for Plex
|
||||||
|
kind: Deployment
|
||||||
|
apiVersion: apps/v1
|
||||||
|
metadata:
|
||||||
|
namespace: plex
|
||||||
|
name: plex
|
||||||
|
labels:
|
||||||
|
app: plex
|
||||||
|
spec:
|
||||||
|
replicas: 1
|
||||||
|
selector:
|
||||||
|
matchLabels:
|
||||||
|
app: plex
|
||||||
|
template:
|
||||||
|
metadata:
|
||||||
|
labels:
|
||||||
|
app: plex
|
||||||
|
spec:
|
||||||
|
volumes:
|
||||||
|
- name: plex-config
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/homelab/config/plex"
|
||||||
|
- name: media-data
|
||||||
|
hostPath:
|
||||||
|
path: "/mnt/sdb1/data"
|
||||||
|
#- name: plex-config-pv
|
||||||
|
# persistentVolumeClaim:
|
||||||
|
# claimName: plex-config
|
||||||
|
#- name: media-data-pv
|
||||||
|
# persistentVolumeClaim:
|
||||||
|
# claimName: media-data
|
||||||
|
containers:
|
||||||
|
- name: plex
|
||||||
|
image: lscr.io/linuxserver/plex
|
||||||
|
volumeMounts:
|
||||||
|
- mountPath: "/config"
|
||||||
|
name: plex-config
|
||||||
|
- mountPath: "/app/data"
|
||||||
|
name: media-data
|
||||||
|
#- mountPath: "/config"
|
||||||
|
# name: plex-config-pv
|
||||||
|
#- mountPath: "/app/data"
|
||||||
|
# name: media-data-pv
|
||||||
|
env:
|
||||||
|
- name: PUID
|
||||||
|
value: "1000"
|
||||||
|
- name: PGID
|
||||||
|
value: "1000"
|
||||||
|
- name: TZ
|
||||||
|
value: Europe/Oslo
|
||||||
|
ports:
|
||||||
|
- name: web
|
||||||
|
containerPort: 32400
|
||||||
|
- name: a
|
||||||
|
containerPort: 1900
|
||||||
|
protocol: UDP
|
||||||
|
- name: b
|
||||||
|
containerPort: 3005
|
||||||
|
- name: c
|
||||||
|
containerPort: 8324
|
||||||
|
- name: d
|
||||||
|
containerPort: 32410
|
||||||
|
protocol: UDP
|
||||||
|
- name: e
|
||||||
|
containerPort: 32412
|
||||||
|
protocol: UDP
|
||||||
|
- name: f
|
||||||
|
containerPort: 32413
|
||||||
|
protocol: UDP
|
||||||
|
- name: g
|
||||||
|
containerPort: 32414
|
||||||
|
protocol: UDP
|
||||||
|
- name: h
|
||||||
|
containerPort: 32469
|
||||||
|
---
|
||||||
|
## IngressRoute for Plex
|
||||||
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
|
kind: IngressRoute
|
||||||
|
metadata:
|
||||||
|
name: ingressroute-plex
|
||||||
|
namespace: plex
|
||||||
|
spec:
|
||||||
|
entryPoints:
|
||||||
|
- websecure
|
||||||
|
routes:
|
||||||
|
- match: Host(`plex.stonegarden.dev`)
|
||||||
|
kind: Rule
|
||||||
|
services:
|
||||||
|
- name: plex
|
||||||
|
port: 32400
|
||||||
|
tls:
|
||||||
|
certResolver: letsencrypt
|
||||||
@@ -1,11 +1,18 @@
|
|||||||
|
# Namespace for whoami
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Namespace
|
||||||
|
metadata:
|
||||||
|
name: whoami
|
||||||
|
label:
|
||||||
|
name: whoami
|
||||||
|
|
||||||
---
|
---
|
||||||
# Service for exposing deployment of whoami
|
# Service for exposing deployment of whoami
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Service
|
kind: Service
|
||||||
metadata:
|
metadata:
|
||||||
namespace: default
|
namespace: whoami
|
||||||
name: whoami
|
name: whoami
|
||||||
|
|
||||||
spec:
|
spec:
|
||||||
type: LoadBalancer
|
type: LoadBalancer
|
||||||
ports:
|
ports:
|
||||||
@@ -20,11 +27,10 @@ spec:
|
|||||||
kind: Deployment
|
kind: Deployment
|
||||||
apiVersion: apps/v1
|
apiVersion: apps/v1
|
||||||
metadata:
|
metadata:
|
||||||
namespace: default
|
namespace: whoami
|
||||||
name: whoami
|
name: whoami
|
||||||
labels:
|
labels:
|
||||||
app: whoami
|
app: whoami
|
||||||
|
|
||||||
spec:
|
spec:
|
||||||
replicas: 2
|
replicas: 2
|
||||||
selector:
|
selector:
|
||||||
@@ -47,8 +53,8 @@ spec:
|
|||||||
apiVersion: traefik.containo.us/v1alpha1
|
apiVersion: traefik.containo.us/v1alpha1
|
||||||
kind: IngressRoute
|
kind: IngressRoute
|
||||||
metadata:
|
metadata:
|
||||||
name: ingressroutetls
|
name: ingressroute-whoami
|
||||||
namespace: default
|
namespace: whoami
|
||||||
spec:
|
spec:
|
||||||
entryPoints:
|
entryPoints:
|
||||||
- websecure
|
- websecure
|
||||||
@@ -8,7 +8,7 @@ volumeBindingMode: WaitForFirstConsumer
|
|||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: PersistentVolume
|
kind: PersistentVolume
|
||||||
metadata:
|
metadata:
|
||||||
name: traefik-certs-pv
|
name: traefik-cert-pv
|
||||||
spec:
|
spec:
|
||||||
capacity:
|
capacity:
|
||||||
storage: 128Mi
|
storage: 128Mi
|
||||||
@@ -1,68 +0,0 @@
|
|||||||
# Namespace for whoami
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Namespace
|
|
||||||
metadata:
|
|
||||||
name: whoami
|
|
||||||
|
|
||||||
---
|
|
||||||
# Service for exposing deployment of whoami
|
|
||||||
apiVersion: v1
|
|
||||||
kind: Service
|
|
||||||
metadata:
|
|
||||||
namespace: whoami
|
|
||||||
name: whoami
|
|
||||||
|
|
||||||
spec:
|
|
||||||
type: LoadBalancer
|
|
||||||
ports:
|
|
||||||
- protocol: TCP
|
|
||||||
name: web
|
|
||||||
port: 80
|
|
||||||
selector:
|
|
||||||
app: whoami
|
|
||||||
|
|
||||||
---
|
|
||||||
# Deployment of whoami
|
|
||||||
kind: Deployment
|
|
||||||
apiVersion: apps/v1
|
|
||||||
metadata:
|
|
||||||
namespace: whoami
|
|
||||||
name: whoami
|
|
||||||
labels:
|
|
||||||
app: whoami
|
|
||||||
|
|
||||||
spec:
|
|
||||||
replicas: 2
|
|
||||||
selector:
|
|
||||||
matchLabels:
|
|
||||||
app: whoami
|
|
||||||
template:
|
|
||||||
metadata:
|
|
||||||
labels:
|
|
||||||
app: whoami
|
|
||||||
spec:
|
|
||||||
containers:
|
|
||||||
- name: whoami
|
|
||||||
image: traefik/whoami
|
|
||||||
ports:
|
|
||||||
- name: web
|
|
||||||
containerPort: 80
|
|
||||||
|
|
||||||
---
|
|
||||||
# IngressRoute for secure whoami address
|
|
||||||
apiVersion: traefik.containo.us/v1alpha1
|
|
||||||
kind: IngressRoute
|
|
||||||
metadata:
|
|
||||||
name: ingressroutetls
|
|
||||||
namespace: whoami
|
|
||||||
spec:
|
|
||||||
entryPoints:
|
|
||||||
- websecure
|
|
||||||
routes:
|
|
||||||
- match: Host(`whoami2.stonegarden.dev`)
|
|
||||||
kind: Rule
|
|
||||||
services:
|
|
||||||
- name: whoami
|
|
||||||
port: 80
|
|
||||||
tls:
|
|
||||||
certResolver: letsencrypt
|
|
||||||
Reference in New Issue
Block a user