Compare commits

...

3 commits

Author SHA1 Message Date
j
b3d6a38309 Reorder 2025-07-12 13:56:53 +10:00
j
54d8507866 GPT rework cloned with db 2025-07-12 13:53:27 +10:00
j
743dc97e15 Remove psql because it was a pain 2025-07-12 13:51:48 +10:00
3 changed files with 83 additions and 91 deletions

View file

@ -1,6 +1,34 @@
--- ---
apiVersion: v1 apiVersion: v1
kind: PersistentVolume kind: PersistentVolume
metadata:
name: linkwarden-pgdata-pv
spec:
capacity:
storage: 5Gi
accessModes:
- ReadWriteOnce
persistentVolumeReclaimPolicy: Retain
storageClassName: local-path
hostPath:
path: /dpool/services/linkwarden/database
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: linkwarden-pgdata-pvc
namespace: home-server
spec:
accessModes:
- ReadWriteOnce
storageClassName: local-path
resources:
requests:
storage: 5Gi
volumeName: linkwarden-pgdata-pv
---
apiVersion: v1
kind: PersistentVolume
metadata: metadata:
name: linkwarden-pv name: linkwarden-pv
spec: spec:
@ -11,7 +39,7 @@ spec:
persistentVolumeReclaimPolicy: Retain persistentVolumeReclaimPolicy: Retain
storageClassName: local-path storageClassName: local-path
hostPath: hostPath:
path: /dpool/services/linkwarden path: /dpool/services/linkwarden/app
--- ---
apiVersion: v1 apiVersion: v1
kind: PersistentVolumeClaim kind: PersistentVolumeClaim
@ -27,18 +55,43 @@ spec:
storage: 5Gi storage: 5Gi
volumeName: linkwarden-pv volumeName: linkwarden-pv
--- ---
apiVersion: v1 apiVersion: apps/v1
kind: Service kind: Deployment
metadata: metadata:
name: linkwarden name: linkwarden-postgres
namespace: home-server namespace: home-server
spec: spec:
replicas: 1
selector: selector:
app: linkwarden matchLabels:
app: linkwarden-postgres
template:
metadata:
labels:
app: linkwarden-postgres
spec:
containers:
- name: postgres
image: postgres:15
env:
- name: POSTGRES_DB
value: linkwarden
- name: POSTGRES_USER
value: linkwardenuser
- name: POSTGRES_PASSWORD
valueFrom:
secretKeyRef:
name: linkwarden-postgres-secret
key: postgres-password
ports: ports:
- port: 3000 - containerPort: 5432
targetPort: 3000 volumeMounts:
protocol: TCP - name: pgdata
mountPath: /var/lib/postgresql/data
volumes:
- name: pgdata
persistentVolumeClaim:
claimName: linkwarden-pgdata-pvc
--- ---
apiVersion: apps/v1 apiVersion: apps/v1
kind: Deployment kind: Deployment
@ -80,9 +133,9 @@ spec:
- name: NODE_ENV - name: NODE_ENV
value: "production" value: "production"
- name: TZ - name: TZ
value: "Australia/Sydney" value: "Australia/Brisbane"
- name: DATABASE_URL - name: DATABASE_URL
value: "file:/data/data.db" value: "postgresql://linkwardenuser:$(POSTGRES_PASSWORD)@linkwarden-postgres.home-server.svc.cluster.local:5432/linkwarden"
volumeMounts: volumeMounts:
- name: linkwarden-data - name: linkwarden-data
mountPath: /data mountPath: /data
@ -91,29 +144,26 @@ spec:
persistentVolumeClaim: persistentVolumeClaim:
claimName: linkwarden-pvc claimName: linkwarden-pvc
--- ---
apiVersion: networking.k8s.io/v1 apiVersion: v1
kind: Ingress kind: Service
metadata: metadata:
name: linkwarden name: linkwarden
namespace: home-server namespace: home-server
annotations:
external-dns.alpha.kubernetes.io/hostname: links.hxme.net
nginx.ingress.kubernetes.io/server-snippet: |
add_header Strict-Transport-Security "max-age=15552000; includeSubDomains" always;
spec: spec:
tls: selector:
- hosts: app: linkwarden
- links.hxme.net ports:
secretName: wildcard-hxme-net - port: 3000
rules: targetPort: 3000
- host: links.hxme.net protocol: TCP
http: ---
paths: apiVersion: v1
- path: / kind: Service
pathType: Prefix metadata:
backend: name: linkwarden-postgres
service: namespace: home-server
name: linkwarden spec:
port: ports:
number: 3000 - port: 5432
selector:
app: linkwarden-postgres

View file

@ -4,7 +4,6 @@ kind: Kustomization
resources: resources:
- mariadb.yaml - mariadb.yaml
- postgres.yaml
- replicator.yaml - replicator.yaml
- namespace.yaml - namespace.yaml
- redis.yaml - redis.yaml

View file

@ -1,57 +0,0 @@
---
apiVersion: v1
kind: Namespace
metadata:
name: postgres-operator-system
---
apiVersion: source.toolkit.fluxcd.io/v1
kind: HelmRepository
metadata:
name: crunchydata-postgres-operator
namespace: flux-system
spec:
interval: 1h
url: oci://registry.developers.crunchydata.com/crunchydata/pgo
---
apiVersion: helm.toolkit.fluxcd.io/v2
kind: HelmRelease
metadata:
name: postgres-operator-crds
namespace: postgres-operator-system
spec:
interval: 30m
chart:
spec:
chart: pgo-crds
version: 5.3.0
sourceRef:
kind: HelmRepository
name: crunchydata-postgres-operator
namespace: flux-system
install:
createNamespace: true
upgrade:
disableWait: true
timeout: 5m
---
apiVersion: helm.toolkit.fluxcd.io/v2
kind: HelmRelease
metadata:
name: postgres-operator
namespace: postgres-operator-system
spec:
interval: 30m
chart:
spec:
chart: postgres-operator
version: 5.3.0
sourceRef:
kind: HelmRepository
name: crunchydata-postgres-operator
namespace: flux-system
install:
createNamespace: true
dependsOn:
- name: postgres-operator-crds
namespace: postgres-operator-system