feat: add longhorn
This commit is contained in:
parent
22ce223ab5
commit
625da51e49
|
@ -1,5 +1,5 @@
|
||||||
apiVersion: kustomize.config.k8s.io/v1beta1
|
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
kind: Kustomization
|
kind: Kustomization
|
||||||
resources: []
|
resources:
|
||||||
#- ./longhorn
|
- ./longhorn
|
||||||
#- ./local-path-provisioner
|
#- ./local-path-provisioner
|
|
@ -0,0 +1,32 @@
|
||||||
|
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
||||||
|
kind: HelmRelease
|
||||||
|
metadata:
|
||||||
|
name: longhorn
|
||||||
|
namespace: longhorn-system
|
||||||
|
spec:
|
||||||
|
interval: 5m
|
||||||
|
chart:
|
||||||
|
spec:
|
||||||
|
chart: longhorn
|
||||||
|
version: "1.5.1"
|
||||||
|
sourceRef:
|
||||||
|
kind: HelmRepository
|
||||||
|
name: longhorn-charts
|
||||||
|
namespace: flux-system
|
||||||
|
|
||||||
|
values:
|
||||||
|
longhornUI:
|
||||||
|
replicas: 1
|
||||||
|
|
||||||
|
ingress:
|
||||||
|
enabled: true
|
||||||
|
annotations:
|
||||||
|
cert-manager.io/cluster-issuer: letsencrypt-production
|
||||||
|
traefik.ingress.kubernetes.io/router.entrypoints: websecure
|
||||||
|
traefik.ingress.kubernetes.io/router.middlewares: traefik-authentik@kubernetescrd
|
||||||
|
host: lnghrn.${SECRET_NEW_DOMAIN}
|
||||||
|
tls: true
|
||||||
|
tlsSecret: wildcard-main-tls
|
||||||
|
|
||||||
|
persistence:
|
||||||
|
defaultClassReplicaCount: 1 # TODO: When the cluster expands, expand the replica count
|
|
@ -0,0 +1,8 @@
|
||||||
|
apiVersion: source.toolkit.fluxcd.io/v1beta2
|
||||||
|
kind: HelmRepository
|
||||||
|
metadata:
|
||||||
|
name: longhorn-charts
|
||||||
|
namespace: flux-system
|
||||||
|
spec:
|
||||||
|
interval: 1m
|
||||||
|
url: https://charts.longhorn.io
|
|
@ -1,178 +0,0 @@
|
||||||
apiVersion: source.toolkit.fluxcd.io/v1beta2
|
|
||||||
kind: HelmRepository
|
|
||||||
metadata:
|
|
||||||
name: longhorn-charts
|
|
||||||
namespace: flux-system
|
|
||||||
spec:
|
|
||||||
interval: 1m
|
|
||||||
url: https://charts.longhorn.io
|
|
||||||
---
|
|
||||||
apiVersion: source.toolkit.fluxcd.io/v1beta2
|
|
||||||
kind: HelmRepository
|
|
||||||
metadata:
|
|
||||||
name: kyverno-charts
|
|
||||||
namespace: flux-system
|
|
||||||
spec:
|
|
||||||
interval: 1m
|
|
||||||
url: https://kyverno.github.io/kyverno
|
|
||||||
---
|
|
||||||
apiVersion: source.toolkit.fluxcd.io/v1beta2
|
|
||||||
kind: HelmRepository
|
|
||||||
metadata:
|
|
||||||
name: raw-charts
|
|
||||||
namespace: flux-system
|
|
||||||
spec:
|
|
||||||
interval: 1m
|
|
||||||
url: https://buttahtoast.github.io/helm-charts/
|
|
||||||
---
|
|
||||||
# ================= Release for longhorn =================
|
|
||||||
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
|
||||||
kind: HelmRelease
|
|
||||||
metadata:
|
|
||||||
name: longhorn
|
|
||||||
namespace: longhorn-system
|
|
||||||
spec:
|
|
||||||
interval: 5m
|
|
||||||
chart:
|
|
||||||
spec:
|
|
||||||
chart: longhorn
|
|
||||||
version: '1.4.x'
|
|
||||||
sourceRef:
|
|
||||||
kind: HelmRepository
|
|
||||||
name: longhorn-charts
|
|
||||||
namespace: flux-system
|
|
||||||
interval: 1m
|
|
||||||
---
|
|
||||||
# ================= Release for kyverno =================
|
|
||||||
apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
|
||||||
kind: HelmRelease
|
|
||||||
metadata:
|
|
||||||
name: kyverno
|
|
||||||
namespace: longhorn-system
|
|
||||||
spec:
|
|
||||||
interval: 5m
|
|
||||||
chart:
|
|
||||||
spec:
|
|
||||||
chart: kyverno
|
|
||||||
version: '2.6.x'
|
|
||||||
sourceRef:
|
|
||||||
kind: HelmRepository
|
|
||||||
name: kyverno-charts
|
|
||||||
namespace: flux-system
|
|
||||||
interval: 1m
|
|
||||||
---
|
|
||||||
# ================= Release for incubator/raw =================
|
|
||||||
#apiVersion: helm.toolkit.fluxcd.io/v2beta1
|
|
||||||
#kind: HelmRelease
|
|
||||||
#metadata:
|
|
||||||
# name: raw
|
|
||||||
# namespace: longhorn-system
|
|
||||||
#spec:
|
|
||||||
# interval: 5m
|
|
||||||
# dependsOn:
|
|
||||||
# - name: kyverno
|
|
||||||
# namespace: longhorn-system
|
|
||||||
# chart:
|
|
||||||
# spec:
|
|
||||||
# chart: raw
|
|
||||||
# version: '2.0.0'
|
|
||||||
# sourceRef:
|
|
||||||
# kind: HelmRepository
|
|
||||||
# name: raw-charts
|
|
||||||
# namespace: flux-system
|
|
||||||
# interval: 1m
|
|
||||||
# values:
|
|
||||||
# resources:
|
|
||||||
# - apiVersion: v1
|
|
||||||
# kind: ConfigMap
|
|
||||||
# metadata:
|
|
||||||
# name: longhorn-custom-path
|
|
||||||
# namespace: longhorn-system
|
|
||||||
# data:
|
|
||||||
# PATH: /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/run/wrappers/bin:/nix/var/nix/profiles/default/bin:/run/current-system/sw/bin
|
|
||||||
# - apiVersion: kyverno.io/v1
|
|
||||||
# kind: ClusterPolicy
|
|
||||||
# metadata:
|
|
||||||
# name: add-host-path-to-longhorn
|
|
||||||
# annotations:
|
|
||||||
# policies.kyverno.io/title: Add Environment Variables from ConfigMap
|
|
||||||
# policies.kyverno.io/subject: Pod
|
|
||||||
# policies.kyverno.io/category: Other
|
|
||||||
# policies.kyverno.io/description: >-
|
|
||||||
# Longhorn invokes executables on the host system, and needs
|
|
||||||
# to be aware of the host systems PATH. This modifies all
|
|
||||||
# deployments such that the PATH is explicitly set to support
|
|
||||||
# NixOS based systems.
|
|
||||||
# spec:
|
|
||||||
# rules:
|
|
||||||
# - name: add-env-vars
|
|
||||||
# match:
|
|
||||||
# resources:
|
|
||||||
# kinds:
|
|
||||||
# - Pod
|
|
||||||
# namespaces:
|
|
||||||
# - longhorn-system
|
|
||||||
# mutate:
|
|
||||||
# patchStrategicMerge:
|
|
||||||
# spec:
|
|
||||||
# initContainers:
|
|
||||||
# - (name): "*"
|
|
||||||
# envFrom:
|
|
||||||
# - configMapRef:
|
|
||||||
# name: longhorn-custom-path
|
|
||||||
# containers:
|
|
||||||
# - (name): "*"
|
|
||||||
# envFrom:
|
|
||||||
# - configMapRef:
|
|
||||||
# name: longhorn-custom-path
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: ConfigMap
|
|
||||||
metadata:
|
|
||||||
name: longhorn-custom-path
|
|
||||||
namespace: longhorn-system
|
|
||||||
data:
|
|
||||||
PATH: /usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:/run/wrappers/bin:/nix/var/nix/profiles/default/bin:/run/current-system/sw/bin
|
|
||||||
---
|
|
||||||
apiVersion: kyverno.io/v1
|
|
||||||
kind: ClusterPolicy
|
|
||||||
metadata:
|
|
||||||
name: add-host-path-to-longhorn
|
|
||||||
annotations:
|
|
||||||
policies.kyverno.io/title: Add Environment Variables from ConfigMap
|
|
||||||
policies.kyverno.io/subject: Pod
|
|
||||||
policies.kyverno.io/category: Other
|
|
||||||
policies.kyverno.io/description: >-
|
|
||||||
Longhorn invokes executables on the host system, and needs
|
|
||||||
to be aware of the host systems PATH. This modifies all
|
|
||||||
deployments such that the PATH is explicitly set to support
|
|
||||||
NixOS based systems.
|
|
||||||
spec:
|
|
||||||
rules:
|
|
||||||
- name: add-env-vars
|
|
||||||
match:
|
|
||||||
resources:
|
|
||||||
kinds:
|
|
||||||
- Pod
|
|
||||||
namespaces:
|
|
||||||
- longhorn-system
|
|
||||||
mutate:
|
|
||||||
patchStrategicMerge:
|
|
||||||
spec:
|
|
||||||
initContainers:
|
|
||||||
- (name): "*"
|
|
||||||
envFrom:
|
|
||||||
- configMapRef:
|
|
||||||
name: longhorn-custom-path
|
|
||||||
containers:
|
|
||||||
- (name): "*"
|
|
||||||
envFrom:
|
|
||||||
- configMapRef:
|
|
||||||
name: longhorn-custom-path
|
|
|
@ -1,20 +0,0 @@
|
||||||
apiVersion: networking.k8s.io/v1
|
|
||||||
kind: Ingress
|
|
||||||
metadata:
|
|
||||||
name: longhorn-ingress
|
|
||||||
namespace: longhorn-system
|
|
||||||
annotations:
|
|
||||||
cert-manager.io/cluster-issuer: letsencrypt-production
|
|
||||||
traefik.ingress.kubernetes.io/router.entrypoints: websecure
|
|
||||||
spec:
|
|
||||||
rules:
|
|
||||||
- host: "longhorn.${SECRET_DOMAIN}"
|
|
||||||
http:
|
|
||||||
paths:
|
|
||||||
- path: /
|
|
||||||
pathType: Prefix
|
|
||||||
backend:
|
|
||||||
service:
|
|
||||||
name: longhorn
|
|
||||||
port:
|
|
||||||
number: 80
|
|
|
@ -2,5 +2,5 @@ apiVersion: kustomize.config.k8s.io/v1beta1
|
||||||
kind: Kustomization
|
kind: Kustomization
|
||||||
resources:
|
resources:
|
||||||
- ./namespace.yaml
|
- ./namespace.yaml
|
||||||
- ./helm.yaml
|
- ./helm-repository.yaml
|
||||||
- ./ingress.yaml
|
- ./helm-release.yaml
|
|
@ -1,4 +1,6 @@
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: Namespace
|
kind: Namespace
|
||||||
metadata:
|
metadata:
|
||||||
name: longhorn-system
|
name: longhorn-system
|
||||||
|
labels:
|
||||||
|
name: longhorn-system
|
Loading…
Reference in New Issue