Compare commits

..

No commits in common. "b3d6a3830946ffacc2ffebc975f7734f903cb249" and "596d2a3959dd06c72ce21d571e02d9bad38a0901" have entirely different histories.

3 changed files with 91 additions and 83 deletions

View file

@ -1,34 +1,6 @@
--- ---
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:
@ -39,7 +11,7 @@ spec:
persistentVolumeReclaimPolicy: Retain persistentVolumeReclaimPolicy: Retain
storageClassName: local-path storageClassName: local-path
hostPath: hostPath:
path: /dpool/services/linkwarden/app path: /dpool/services/linkwarden
--- ---
apiVersion: v1 apiVersion: v1
kind: PersistentVolumeClaim kind: PersistentVolumeClaim
@ -55,43 +27,18 @@ spec:
storage: 5Gi storage: 5Gi
volumeName: linkwarden-pv volumeName: linkwarden-pv
--- ---
apiVersion: apps/v1 apiVersion: v1
kind: Deployment kind: Service
metadata: metadata:
name: linkwarden-postgres name: linkwarden
namespace: home-server namespace: home-server
spec: spec:
replicas: 1
selector: selector:
matchLabels: app: linkwarden
app: linkwarden-postgres ports:
template: - port: 3000
metadata: targetPort: 3000
labels: protocol: TCP
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:
- containerPort: 5432
volumeMounts:
- 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
@ -133,9 +80,9 @@ spec:
- name: NODE_ENV - name: NODE_ENV
value: "production" value: "production"
- name: TZ - name: TZ
value: "Australia/Brisbane" value: "Australia/Sydney"
- name: DATABASE_URL - name: DATABASE_URL
value: "postgresql://linkwardenuser:$(POSTGRES_PASSWORD)@linkwarden-postgres.home-server.svc.cluster.local:5432/linkwarden" value: "file:/data/data.db"
volumeMounts: volumeMounts:
- name: linkwarden-data - name: linkwarden-data
mountPath: /data mountPath: /data
@ -144,26 +91,29 @@ spec:
persistentVolumeClaim: persistentVolumeClaim:
claimName: linkwarden-pvc claimName: linkwarden-pvc
--- ---
apiVersion: v1 apiVersion: networking.k8s.io/v1
kind: Service kind: Ingress
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:
selector: tls:
app: linkwarden - hosts:
ports: - links.hxme.net
- port: 3000 secretName: wildcard-hxme-net
targetPort: 3000 rules:
protocol: TCP - host: links.hxme.net
--- http:
apiVersion: v1 paths:
kind: Service - path: /
metadata: pathType: Prefix
name: linkwarden-postgres backend:
namespace: home-server service:
spec: name: linkwarden
ports: port:
- port: 5432 number: 3000
selector:
app: linkwarden-postgres

View file

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

View file

@ -0,0 +1,57 @@
---
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