harbor: deploy chart via flux
This commit is contained in:
parent
aa0df1f62b
commit
dba7cf00a4
@ -0,0 +1,18 @@
|
||||
# clusters/atlas/flux-system/applications/harbor/kustomization.yaml
|
||||
apiVersion: kustomize.toolkit.fluxcd.io/v1
|
||||
kind: Kustomization
|
||||
metadata:
|
||||
name: harbor
|
||||
namespace: flux-system
|
||||
spec:
|
||||
interval: 10m
|
||||
path: ./services/harbor
|
||||
targetNamespace: harbor
|
||||
prune: false
|
||||
sourceRef:
|
||||
kind: GitRepository
|
||||
name: flux-system
|
||||
namespace: flux-system
|
||||
wait: true
|
||||
dependsOn:
|
||||
- name: core
|
||||
9
infrastructure/sources/helm/harbor.yaml
Normal file
9
infrastructure/sources/helm/harbor.yaml
Normal file
@ -0,0 +1,9 @@
|
||||
# infrastructure/sources/helm/harbor.yaml
|
||||
apiVersion: source.toolkit.fluxcd.io/v1beta2
|
||||
kind: HelmRepository
|
||||
metadata:
|
||||
name: harbor
|
||||
namespace: flux-system
|
||||
spec:
|
||||
interval: 10m
|
||||
url: https://helm.goharbor.io
|
||||
12
services/harbor/certificate.yaml
Normal file
12
services/harbor/certificate.yaml
Normal file
@ -0,0 +1,12 @@
|
||||
# services/harbor/certificate.yaml
|
||||
apiVersion: cert-manager.io/v1
|
||||
kind: Certificate
|
||||
metadata:
|
||||
name: registry-bstein-dev
|
||||
namespace: harbor
|
||||
spec:
|
||||
secretName: registry-bstein-dev-tls
|
||||
dnsNames: [ "registry.bstein.dev" ]
|
||||
issuerRef:
|
||||
name: letsencrypt
|
||||
kind: ClusterIssuer
|
||||
71
services/harbor/helmrelease.yaml
Normal file
71
services/harbor/helmrelease.yaml
Normal file
@ -0,0 +1,71 @@
|
||||
# services/harbor/helmrelease.yaml
|
||||
apiVersion: helm.toolkit.fluxcd.io/v2beta2
|
||||
kind: HelmRelease
|
||||
metadata:
|
||||
name: harbor
|
||||
namespace: harbor
|
||||
spec:
|
||||
interval: 10m
|
||||
chart:
|
||||
spec:
|
||||
chart: harbor
|
||||
version: 1.18.1
|
||||
sourceRef:
|
||||
kind: HelmRepository
|
||||
name: harbor
|
||||
namespace: flux-system
|
||||
values:
|
||||
externalURL: https://registry.bstein.dev
|
||||
expose:
|
||||
type: ingress
|
||||
tls:
|
||||
enabled: true
|
||||
certSource: secret
|
||||
secret:
|
||||
secretName: registry-bstein-dev-tls
|
||||
ingress:
|
||||
className: traefik
|
||||
annotations:
|
||||
cert-manager.io/cluster-issuer: letsencrypt
|
||||
traefik.ingress.kubernetes.io/router.entrypoints: websecure
|
||||
traefik.ingress.kubernetes.io/router.tls: "true"
|
||||
hosts:
|
||||
core: registry.bstein.dev
|
||||
persistence:
|
||||
enabled: true
|
||||
resourcePolicy: keep
|
||||
persistentVolumeClaim:
|
||||
registry:
|
||||
existingClaim: harbor-registry
|
||||
accessMode: ReadWriteOnce
|
||||
size: 50Gi
|
||||
jobservice:
|
||||
jobLog:
|
||||
existingClaim: harbor-jobservice-logs
|
||||
accessMode: ReadWriteOnce
|
||||
size: 5Gi
|
||||
imageChartStorage:
|
||||
type: filesystem
|
||||
filesystem:
|
||||
rootdirectory: /storage
|
||||
database:
|
||||
type: external
|
||||
external:
|
||||
host: postgres-service.postgres.svc.cluster.local
|
||||
port: "5432"
|
||||
username: harbor
|
||||
coreDatabase: harbor
|
||||
existingSecret: harbor-db
|
||||
sslmode: disable
|
||||
redis:
|
||||
type: internal
|
||||
trivy:
|
||||
enabled: false
|
||||
metrics:
|
||||
enabled: false
|
||||
cache:
|
||||
enabled: false
|
||||
existingSecretAdminPassword: harbor-core
|
||||
existingSecretAdminPasswordKey: HARBOR_ADMIN_PASSWORD
|
||||
updateStrategy:
|
||||
type: Recreate
|
||||
9
services/harbor/kustomization.yaml
Normal file
9
services/harbor/kustomization.yaml
Normal file
@ -0,0 +1,9 @@
|
||||
# services/harbor/kustomization.yaml
|
||||
apiVersion: kustomize.config.k8s.io/v1beta1
|
||||
kind: Kustomization
|
||||
namespace: harbor
|
||||
resources:
|
||||
- namespace.yaml
|
||||
- pvc.yaml
|
||||
- certificate.yaml
|
||||
- helmrelease.yaml
|
||||
5
services/harbor/namespace.yaml
Normal file
5
services/harbor/namespace.yaml
Normal file
@ -0,0 +1,5 @@
|
||||
# services/harbor/namespace.yaml
|
||||
apiVersion: v1
|
||||
kind: Namespace
|
||||
metadata:
|
||||
name: harbor
|
||||
24
services/harbor/pvc.yaml
Normal file
24
services/harbor/pvc.yaml
Normal file
@ -0,0 +1,24 @@
|
||||
# services/harbor/pvc.yaml
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: harbor-registry
|
||||
namespace: harbor
|
||||
spec:
|
||||
accessModes: [ "ReadWriteOnce" ]
|
||||
resources:
|
||||
requests:
|
||||
storage: 50Gi
|
||||
storageClassName: asteria
|
||||
---
|
||||
apiVersion: v1
|
||||
kind: PersistentVolumeClaim
|
||||
metadata:
|
||||
name: harbor-jobservice-logs
|
||||
namespace: harbor
|
||||
spec:
|
||||
accessModes: [ "ReadWriteOnce" ]
|
||||
resources:
|
||||
requests:
|
||||
storage: 5Gi
|
||||
storageClassName: asteria
|
||||
Loading…
x
Reference in New Issue
Block a user