feat: v1.28 version upgrade argoCD incl. move into argo umbrella chart
This commit is contained in:
parent
cfeea63555
commit
587398a490
@ -8,27 +8,11 @@ import yaml
|
|||||||
def migrate(values):
|
def migrate(values):
|
||||||
"""Actual changes here"""
|
"""Actual changes here"""
|
||||||
|
|
||||||
# Cleanup
|
# argoCD moves to argo module
|
||||||
values.pop("Domain", None)
|
|
||||||
values.pop("clusterName", None)
|
|
||||||
if "addons" in values:
|
|
||||||
if not values["addons"]:
|
|
||||||
values.pop("addons")
|
|
||||||
|
|
||||||
# fix argoCD CM
|
|
||||||
try:
|
try:
|
||||||
if not values["argocd"]["configs"]["cm"]["url"].startswith("http"):
|
if values["argocd"]["enabled"]:
|
||||||
values["argocd"]["configs"]["cm"]["url"] = "https://" + values["argocd"]["configs"]["cm"]["url"]
|
values["argo"] = { "enabled": True, "argo-cd": values["argocd"] }
|
||||||
except KeyError:
|
values.pop("argocd")
|
||||||
pass
|
|
||||||
|
|
||||||
# migrate eck operator to new operator module
|
|
||||||
try:
|
|
||||||
if values["logging"]["eck-operator"]["enabled"]:
|
|
||||||
if "operators" not in values:
|
|
||||||
values["operators"] = { "enabled": True }
|
|
||||||
values["operators"]["eck-operator"] = { "enabled": True }
|
|
||||||
values["logging"].pop("eck-operator", None)
|
|
||||||
except KeyError:
|
except KeyError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@ -31,7 +31,14 @@ waitSystemPodsRunning
|
|||||||
|
|
||||||
echo "Applying remaining KubeZero modules..."
|
echo "Applying remaining KubeZero modules..."
|
||||||
|
|
||||||
control_plane_upgrade "apply_cert-manager, apply_istio, apply_istio-ingress, apply_istio-private-ingress, apply_logging, apply_metrics, apply_telemetry, apply_argocd"
|
### v1.28
|
||||||
|
# - remove old argocd app, all resources will be taken over by argo.argo-cd
|
||||||
|
kubectl patch app argocd -n argocd \
|
||||||
|
--type json \
|
||||||
|
--patch='[ { "op": "remove", "path": "/metadata/finalizers" } ]' && \
|
||||||
|
kubectl delete app argocd -n argocd || true
|
||||||
|
|
||||||
|
control_plane_upgrade "apply_cert-manager, apply_istio, apply_istio-ingress, apply_istio-private-ingress, apply_logging, apply_metrics, apply_telemetry, apply_argo"
|
||||||
|
|
||||||
# Trigger backup of upgraded cluster state
|
# Trigger backup of upgraded cluster state
|
||||||
kubectl create job --from=cronjob/kubezero-backup kubezero-backup-$VERSION -n kube-system
|
kubectl create job --from=cronjob/kubezero-backup kubezero-backup-$VERSION -n kube-system
|
||||||
|
@ -1,11 +1,12 @@
|
|||||||
apiVersion: v2
|
apiVersion: v2
|
||||||
description: KubeZero Argo - Events, Workflow, CD
|
description: KubeZero Argo - Events, Workflow, CD
|
||||||
name: kubezero-argo
|
name: kubezero-argo
|
||||||
version: 0.1.1
|
version: 0.2.0
|
||||||
home: https://kubezero.com
|
home: https://kubezero.com
|
||||||
icon: https://cdn.zero-downtime.net/assets/kubezero/logo-small-64.png
|
icon: https://cdn.zero-downtime.net/assets/kubezero/logo-small-64.png
|
||||||
keywords:
|
keywords:
|
||||||
- kubezero
|
- kubezero
|
||||||
|
- argocd
|
||||||
- argo-events
|
- argo-events
|
||||||
- argo-workflow
|
- argo-workflow
|
||||||
maintainers:
|
maintainers:
|
||||||
@ -20,4 +21,16 @@ dependencies:
|
|||||||
version: 2.4.4
|
version: 2.4.4
|
||||||
repository: https://argoproj.github.io/argo-helm
|
repository: https://argoproj.github.io/argo-helm
|
||||||
condition: argo-events.enabled
|
condition: argo-events.enabled
|
||||||
|
- name: argo-cd
|
||||||
|
version: 6.7.3
|
||||||
|
repository: https://argoproj.github.io/argo-helm
|
||||||
|
condition: argo-cd.enabled
|
||||||
|
- name: argocd-apps
|
||||||
|
version: 2.0.0
|
||||||
|
repository: https://argoproj.github.io/argo-helm
|
||||||
|
condition: argo-cd.enabled
|
||||||
|
- name: argocd-image-updater
|
||||||
|
version: 0.9.6
|
||||||
|
repository: https://argoproj.github.io/argo-helm
|
||||||
|
condition: argocd-image-updater.enabled
|
||||||
kubeVersion: ">= 1.26.0"
|
kubeVersion: ">= 1.26.0"
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
# kubezero-argo
|
# kubezero-argo
|
||||||
|
|
||||||
![Version: 0.1.0](https://img.shields.io/badge/Version-0.1.0-informational?style=flat-square)
|
![Version: 0.2.0](https://img.shields.io/badge/Version-0.2.0-informational?style=flat-square)
|
||||||
|
|
||||||
KubeZero Argo - Events, Workflow, CD
|
KubeZero Argo - Events, Workflow, CD
|
||||||
|
|
||||||
@ -18,13 +18,48 @@ Kubernetes: `>= 1.26.0`
|
|||||||
|
|
||||||
| Repository | Name | Version |
|
| Repository | Name | Version |
|
||||||
|------------|------|---------|
|
|------------|------|---------|
|
||||||
| https://argoproj.github.io/argo-helm | argo-events | 2.4.3 |
|
| https://argoproj.github.io/argo-helm | argo-cd | 6.7.3 |
|
||||||
|
| https://argoproj.github.io/argo-helm | argo-events | 2.4.4 |
|
||||||
|
| https://argoproj.github.io/argo-helm | argocd-apps | 2.0.0 |
|
||||||
|
| https://argoproj.github.io/argo-helm | argocd-image-updater | 0.9.6 |
|
||||||
| https://cdn.zero-downtime.net/charts/ | kubezero-lib | >= 0.1.6 |
|
| https://cdn.zero-downtime.net/charts/ | kubezero-lib | >= 0.1.6 |
|
||||||
|
|
||||||
## Values
|
## Values
|
||||||
|
|
||||||
| Key | Type | Default | Description |
|
| Key | Type | Default | Description |
|
||||||
|-----|------|---------|-------------|
|
|-----|------|---------|-------------|
|
||||||
|
| argo-cd.applicationSet.enabled | bool | `false` | |
|
||||||
|
| argo-cd.configs.cm."resource.customizations" | string | `"cert-manager.io/Certificate:\n # Lua script for customizing the health status assessment\n health.lua: |\n hs = {}\n if obj.status ~= nil then\n if obj.status.conditions ~= nil then\n for i, condition in ipairs(obj.status.conditions) do\n if condition.type == \"Ready\" and condition.status == \"False\" then\n hs.status = \"Degraded\"\n hs.message = condition.message\n return hs\n end\n if condition.type == \"Ready\" and condition.status == \"True\" then\n hs.status = \"Healthy\"\n hs.message = condition.message\n return hs\n end\n end\n end\n end\n hs.status = \"Progressing\"\n hs.message = \"Waiting for certificate\"\n return hs\n"` | |
|
||||||
|
| argo-cd.configs.cm."timeout.reconciliation" | int | `300` | |
|
||||||
|
| argo-cd.configs.cm."ui.bannercontent" | string | `"KubeZero v1.27 - Release notes"` | |
|
||||||
|
| argo-cd.configs.cm."ui.bannerpermanent" | string | `"true"` | |
|
||||||
|
| argo-cd.configs.cm."ui.bannerposition" | string | `"bottom"` | |
|
||||||
|
| argo-cd.configs.cm."ui.bannerurl" | string | `"https://kubezero.com/releases/v1.27"` | |
|
||||||
|
| argo-cd.configs.cm.url | string | `"https://argocd.example.com"` | |
|
||||||
|
| argo-cd.configs.knownHosts.data.ssh_known_hosts | string | `"bitbucket.org ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBPIQmuzMBuKdWeF4+a2sjSSpBK0iqitSQ+5BM9KhpexuGt20JpTVM7u5BDZngncgrqDMbWdxMWWOGtZ9UgbqgZE=\nbitbucket.org ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIazEu89wgQZ4bqs3d63QSMzYVa0MuJ2e2gKTKqu+UUO\nbitbucket.org ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDQeJzhupRu0u0cdegZIa8e86EG2qOCsIsD1Xw0xSeiPDlCr7kq97NLmMbpKTX6Esc30NuoqEEHCuc7yWtwp8dI76EEEB1VqY9QJq6vk+aySyboD5QF61I/1WeTwu+deCbgKMGbUijeXhtfbxSxm6JwGrXrhBdofTsbKRUsrN1WoNgUa8uqN1Vx6WAJw1JHPhglEGGHea6QICwJOAr/6mrui/oB7pkaWKHj3z7d1IC4KWLtY47elvjbaTlkN04Kc/5LFEirorGYVbt15kAUlqGM65pk6ZBxtaO3+30LVlORZkxOh+LKL/BvbZ/iRNhItLqNyieoQj/uh/7Iv4uyH/cV/0b4WDSd3DptigWq84lJubb9t/DnZlrJazxyDCulTmKdOR7vs9gMTo+uoIrPSb8ScTtvw65+odKAlBj59dhnVp9zd7QUojOpXlL62Aw56U4oO+FALuevvMjiWeavKhJqlR7i5n9srYcrNV7ttmDw7kf/97P5zauIhxcjX+xHv4M=\ngithub.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBEmKSENjQEezOmxkZMy7opKgwFB9nkt5YRrYMjNuG5N87uRgg6CLrbo5wAdT/y6v0mKV0U2w0WZ2YB/++Tpockg=\ngithub.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOMqqnkVzrm0SdG6UOoqKLsabgH5C9okWi0dh2l9GKJl\ngithub.com ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAq2A7hRGmdnm9tUDbO9IDSwBK6TbQa+PXYPCPy6rbTrTtw7PHkccKrpp0yVhp5HdEIcKr6pLlVDBfOLX9QUsyCOV0wzfjIJNlGEYsdlLJizHhbn2mUjvSAHQqZETYP81eFzLQNnPHt4EVVUh7VfDESU84KezmD5QlWpXLmvU31/yMf+Se8xhHTvKSCZIFImWwoG6mbUoWf9nzpIoaSjB+weqqUUmpaaasXVal72J+UX2B+2RPW3RcT0eOzQgqlJL3RKrTJvdsjE3JEAvGq3lGHSZXy28G3skua2SmVi/w4yCE6gbODqnTWlg7+wC604ydGXA8VJiS5ap43JXiUFFAaQ==\ngitlab.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBFSMqzJeV9rUzU4kWitGjeR4PWSa29SPqJ1fVkhtj3Hw9xjLVXVYrU9QlYWrOLXBpQ6KWjbjTDTdDkoohFzgbEY=\ngitlab.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAfuCHKVTjquxvt6CM6tdG4SLp1Btn/nOeHHE5UOzRdf\ngitlab.com ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCsj2bNKTBSpIYDEGk9KxsGh3mySTRgMtXL583qmBpzeQ+jqCMRgBqB98u3z++J1sKlXHWfM9dyhSevkMwSbhoR8XIq/U0tCNyokEi/ueaBMCvbcTHhO7FcwzY92WK4Yt0aGROY5qX2UKSeOvuP4D6TPqKF1onrSzH9bx9XUf2lEdWT/ia1NEKjunUqu1xOB/StKDHMoX4/OKyIzuS0q/T1zOATthvasJFoPrAjkohTyaDUz2LN5JoH839hViyEG82yB+MjcFV5MU3N1l1QL3cVUCh93xSaua1N85qivl+siMkPGbO5xR/En4iEY6K2XPASUEMaieWVNTRCtJ4S8H+9\ngit.zero-downtime.net ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC8YdJ4YcOK7A0K7qOWsRjCS+wHTStXRcwBe7gjG43HPSNijiCKoGf/c+tfNsRhyouawg7Law6M6ahmS/jKWBpznRIM+OdOFVSuhnK/nr6h6wG3/ZfdLicyAPvx1/STGY/Fc6/zXA88i/9PV+g84gSVmhf3fGY92wokiASiu9DU4T9dT1gIkdyOX6fbMi1/mMKLSrHnAQcjyasYDvw9ISCJ95EoSwbj7O4c+7jo9fxYvdCfZZZAEZGozTRLAAO0AnjVcRah7bZV/jfHJuhOipV/TB7UVAhlVv1dfGV7hoTp9UKtKZFJF4cjIrSGxqQA/mdhSdLgkepK7yc4Jp2xGnaarhY29DfqsQqop+ugFpTbj7Xy5Rco07mXc6XssbAZhI1xtCOX20N4PufBuYippCK5AE6AiAyVtJmvfGQk4HP+TjOyhFo7PZm3wc9Hym7IBBVC0Sl30K8ddufkAgHwNGvvu1ZmD9ZWaMOXJDHBCZGMMr16QREZwVtZTwMEQalc7/yqmuqMhmcJIfs/GA2Lt91y+pq9C8XyeUL0VFPch0vkcLSRe3ghMZpRFJ/ht307xPcLzgTJqN6oQtNNDzSQglSEjwhge2K4GyWcIh+oGsWxWz5dHyk1iJmw90Y976BZIl/mYVgbTtZAJ81oGe/0k5rAe+LDL+Yq6tG28QFOg0QmiQ==\n"` | |
|
||||||
|
| argo-cd.configs.params."controller.operation.processors" | string | `"5"` | |
|
||||||
|
| argo-cd.configs.params."controller.status.processors" | string | `"10"` | |
|
||||||
|
| argo-cd.configs.params."server.enable.gzip" | bool | `true` | |
|
||||||
|
| argo-cd.configs.params."server.insecure" | bool | `true` | |
|
||||||
|
| argo-cd.configs.secret.createSecret | bool | `false` | |
|
||||||
|
| argo-cd.configs.styles | string | `".sidebar__logo img { content: url(https://cdn.zero-downtime.net/assets/kubezero/logo-small-64.png); }\n.sidebar__logo__text-logo { height: 0em; }\n.sidebar { background: linear-gradient(to bottom, #6A4D79, #493558, #2D1B30, #0D0711); }\n"` | |
|
||||||
|
| argo-cd.controller.metrics.enabled | bool | `false` | |
|
||||||
|
| argo-cd.controller.metrics.serviceMonitor.enabled | bool | `true` | |
|
||||||
|
| argo-cd.controller.resources.limits.memory | string | `"2048Mi"` | |
|
||||||
|
| argo-cd.controller.resources.requests.cpu | string | `"100m"` | |
|
||||||
|
| argo-cd.controller.resources.requests.memory | string | `"512Mi"` | |
|
||||||
|
| argo-cd.dex.enabled | bool | `false` | |
|
||||||
|
| argo-cd.enabled | bool | `false` | |
|
||||||
|
| argo-cd.global.logging.format | string | `"json"` | |
|
||||||
|
| argo-cd.istio.enabled | bool | `false` | |
|
||||||
|
| argo-cd.istio.gateway | string | `"istio-ingress/ingressgateway"` | |
|
||||||
|
| argo-cd.istio.ipBlocks | list | `[]` | |
|
||||||
|
| argo-cd.notifications.enabled | bool | `false` | |
|
||||||
|
| argo-cd.repoServer.metrics.enabled | bool | `false` | |
|
||||||
|
| argo-cd.repoServer.metrics.serviceMonitor.enabled | bool | `true` | |
|
||||||
|
| argo-cd.server.metrics.enabled | bool | `false` | |
|
||||||
|
| argo-cd.server.metrics.serviceMonitor.enabled | bool | `true` | |
|
||||||
|
| argo-cd.server.service.servicePortHttpsName | string | `"grpc"` | |
|
||||||
| argo-events.configs.jetstream.settings.maxFileStore | int | `-1` | Maximum size of the file storage (e.g. 20G) |
|
| argo-events.configs.jetstream.settings.maxFileStore | int | `-1` | Maximum size of the file storage (e.g. 20G) |
|
||||||
| argo-events.configs.jetstream.settings.maxMemoryStore | int | `-1` | Maximum size of the memory storage (e.g. 1G) |
|
| argo-events.configs.jetstream.settings.maxMemoryStore | int | `-1` | Maximum size of the memory storage (e.g. 1G) |
|
||||||
| argo-events.configs.jetstream.streamConfig.duplicates | string | `"300s"` | Not documented at the moment |
|
| argo-events.configs.jetstream.streamConfig.duplicates | string | `"300s"` | Not documented at the moment |
|
||||||
@ -38,6 +73,20 @@ Kubernetes: `>= 1.26.0`
|
|||||||
| argo-events.configs.jetstream.versions[0].startCommand | string | `"/nats-server"` | |
|
| argo-events.configs.jetstream.versions[0].startCommand | string | `"/nats-server"` | |
|
||||||
| argo-events.configs.jetstream.versions[0].version | string | `"2.10.11"` | |
|
| argo-events.configs.jetstream.versions[0].version | string | `"2.10.11"` | |
|
||||||
| argo-events.enabled | bool | `false` | |
|
| argo-events.enabled | bool | `false` | |
|
||||||
|
| argocd-apps.applications | object | `{}` | |
|
||||||
|
| argocd-apps.enabled | bool | `false` | |
|
||||||
|
| argocd-apps.projects | object | `{}` | |
|
||||||
|
| argocd-image-updater.authScripts.enabled | bool | `true` | |
|
||||||
|
| argocd-image-updater.authScripts.scripts."ecr-login.sh" | string | `"#!/bin/sh\naws ecr --region $AWS_REGION get-authorization-token --output text --query 'authorizationData[].authorizationToken' | base64 -d\n"` | |
|
||||||
|
| argocd-image-updater.authScripts.scripts."ecr-public-login.sh" | string | `"#!/bin/sh\naws ecr-public --region us-east-1 get-authorization-token --output text --query 'authorizationData.authorizationToken' | base64 -d\n"` | |
|
||||||
|
| argocd-image-updater.config.argocd.plaintext | bool | `true` | |
|
||||||
|
| argocd-image-updater.enabled | bool | `false` | |
|
||||||
|
| argocd-image-updater.fullnameOverride | string | `"argocd-image-updater"` | |
|
||||||
|
| argocd-image-updater.metrics.enabled | bool | `false` | |
|
||||||
|
| argocd-image-updater.metrics.serviceMonitor.enabled | bool | `true` | |
|
||||||
|
| argocd-image-updater.sshConfig.config | string | `"Host *\n PubkeyAcceptedAlgorithms +ssh-rsa\n HostkeyAlgorithms +ssh-rsa\n"` | |
|
||||||
|
|
||||||
## Resources
|
## Resources
|
||||||
|
- https://argoproj.github.io/argo-cd/operator-manual/metrics/
|
||||||
|
- https://raw.githubusercontent.com/argoproj/argo-cd/master/examples/dashboard.json
|
||||||
|
|
||||||
|
@ -16,4 +16,6 @@
|
|||||||
{{ template "chart.valuesSection" . }}
|
{{ template "chart.valuesSection" . }}
|
||||||
|
|
||||||
## Resources
|
## Resources
|
||||||
|
- https://argoproj.github.io/argo-cd/operator-manual/metrics/
|
||||||
|
- https://raw.githubusercontent.com/argoproj/argo-cd/master/examples/dashboard.json
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ spec:
|
|||||||
- from:
|
- from:
|
||||||
- source:
|
- source:
|
||||||
notIpBlocks:
|
notIpBlocks:
|
||||||
{{- toYaml .Values.istio.ipBlocks | nindent 8 }}
|
{{- toYaml (index .Values "argo-cd" "istio" "ipBlocks") | nindent 8 }}
|
||||||
to:
|
to:
|
||||||
- operation:
|
- operation:
|
||||||
hosts: [{{ index .Values "argo-cd" "configs" "cm" "url" | quote }}]
|
hosts: [{{ index .Values "argo-cd" "configs" "cm" "url" | quote }}]
|
||||||
|
@ -8,7 +8,7 @@ metadata:
|
|||||||
{{- include "kubezero-lib.labels" . | nindent 4 }}
|
{{- include "kubezero-lib.labels" . | nindent 4 }}
|
||||||
spec:
|
spec:
|
||||||
gateways:
|
gateways:
|
||||||
- {{ .Values.istio.gateway }}
|
- {{ index .Values "argo-cd" "istio" "gateway" }}
|
||||||
hosts:
|
hosts:
|
||||||
- {{ get (urlParse (index .Values "argo-cd" "configs" "cm" "url")) "host" }}
|
- {{ get (urlParse (index .Values "argo-cd" "configs" "cm" "url")) "host" }}
|
||||||
http:
|
http:
|
||||||
@ -19,13 +19,13 @@ spec:
|
|||||||
prefix: argocd-client
|
prefix: argocd-client
|
||||||
route:
|
route:
|
||||||
- destination:
|
- destination:
|
||||||
host: argocd-server
|
host: argo-argocd-server
|
||||||
port:
|
port:
|
||||||
number: 443
|
number: 443
|
||||||
- name: http
|
- name: http
|
||||||
route:
|
route:
|
||||||
- destination:
|
- destination:
|
||||||
host: argocd-server
|
host: argo-argocd-server
|
||||||
port:
|
port:
|
||||||
number: 80
|
number: 80
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
@ -5,6 +5,6 @@
|
|||||||
update_helm
|
update_helm
|
||||||
|
|
||||||
# Create ZDT dashboard configmap
|
# Create ZDT dashboard configmap
|
||||||
#../kubezero-metrics/sync_grafana_dashboards.py dashboards.yaml templates/grafana-dashboards.yaml
|
../kubezero-metrics/sync_grafana_dashboards.py dashboards.yaml templates/argo-cd/grafana-dashboards.yaml
|
||||||
|
|
||||||
update_docs
|
update_docs
|
||||||
|
@ -30,3 +30,157 @@ argo-events:
|
|||||||
configReloaderImage: natsio/nats-server-config-reloader:0.14.1
|
configReloaderImage: natsio/nats-server-config-reloader:0.14.1
|
||||||
startCommand: /nats-server
|
startCommand: /nats-server
|
||||||
|
|
||||||
|
|
||||||
|
argocd-apps:
|
||||||
|
enabled: false
|
||||||
|
projects: {}
|
||||||
|
applications: {}
|
||||||
|
|
||||||
|
argo-cd:
|
||||||
|
enabled: false
|
||||||
|
#configs:
|
||||||
|
# secret:
|
||||||
|
# `htpasswd -nbBC 10 "" $ARGO_PWD | tr -d ':\n' | sed 's/$2y/$2a/'`
|
||||||
|
# argocdServerAdminPassword: "$2a$10$ivKzaXVxMqdeDSfS3nqi1Od3iDbnL7oXrixzDfZFRHlXHnAG6LydG"
|
||||||
|
# argocdServerAdminPasswordMtime: "2020-04-24T15:33:09BST"
|
||||||
|
|
||||||
|
global:
|
||||||
|
logging:
|
||||||
|
format: json
|
||||||
|
# image:
|
||||||
|
# tag: v2.1.6
|
||||||
|
|
||||||
|
configs:
|
||||||
|
styles: |
|
||||||
|
.sidebar__logo img { content: url(https://cdn.zero-downtime.net/assets/kubezero/logo-small-64.png); }
|
||||||
|
.sidebar__logo__text-logo { height: 0em; }
|
||||||
|
.sidebar { background: linear-gradient(to bottom, #6A4D79, #493558, #2D1B30, #0D0711); }
|
||||||
|
|
||||||
|
cm:
|
||||||
|
ui.bannercontent: "KubeZero v1.27 - Release notes"
|
||||||
|
ui.bannerurl: "https://kubezero.com/releases/v1.27"
|
||||||
|
ui.bannerpermanent: "true"
|
||||||
|
ui.bannerposition: "bottom"
|
||||||
|
|
||||||
|
# argo-cd.server.config.url -- ArgoCD URL being exposed via Istio
|
||||||
|
url: https://argocd.example.com
|
||||||
|
|
||||||
|
timeout.reconciliation: 300s
|
||||||
|
|
||||||
|
resource.customizations: |
|
||||||
|
cert-manager.io/Certificate:
|
||||||
|
# Lua script for customizing the health status assessment
|
||||||
|
health.lua: |
|
||||||
|
hs = {}
|
||||||
|
if obj.status ~= nil then
|
||||||
|
if obj.status.conditions ~= nil then
|
||||||
|
for i, condition in ipairs(obj.status.conditions) do
|
||||||
|
if condition.type == "Ready" and condition.status == "False" then
|
||||||
|
hs.status = "Degraded"
|
||||||
|
hs.message = condition.message
|
||||||
|
return hs
|
||||||
|
end
|
||||||
|
if condition.type == "Ready" and condition.status == "True" then
|
||||||
|
hs.status = "Healthy"
|
||||||
|
hs.message = condition.message
|
||||||
|
return hs
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
hs.status = "Progressing"
|
||||||
|
hs.message = "Waiting for certificate"
|
||||||
|
return hs
|
||||||
|
|
||||||
|
secret:
|
||||||
|
createSecret: false
|
||||||
|
|
||||||
|
ssh:
|
||||||
|
extraHosts: "git.zero-downtime.net ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC8YdJ4YcOK7A0K7qOWsRjCS+wHTStXRcwBe7gjG43HPSNijiCKoGf/c+tfNsRhyouawg7Law6M6ahmS/jKWBpznRIM+OdOFVSuhnK/nr6h6wG3/ZfdLicyAPvx1/STGY/Fc6/zXA88i/9PV+g84gSVmhf3fGY92wokiASiu9DU4T9dT1gIkdyOX6fbMi1/mMKLSrHnAQcjyasYDvw9ISCJ95EoSwbj7O4c+7jo9fxYvdCfZZZAEZGozTRLAAO0AnjVcRah7bZV/jfHJuhOipV/TB7UVAhlVv1dfGV7hoTp9UKtKZFJF4cjIrSGxqQA/mdhSdLgkepK7yc4Jp2xGnaarhY29DfqsQqop+ugFpTbj7Xy5Rco07mXc6XssbAZhI1xtCOX20N4PufBuYippCK5AE6AiAyVtJmvfGQk4HP+TjOyhFo7PZm3wc9Hym7IBBVC0Sl30K8ddufkAgHwNGvvu1ZmD9ZWaMOXJDHBCZGMMr16QREZwVtZTwMEQalc7/yqmuqMhmcJIfs/GA2Lt91y+pq9C8XyeUL0VFPch0vkcLSRe3ghMZpRFJ/ht307xPcLzgTJqN6oQtNNDzSQglSEjwhge2K4GyWcIh+oGsWxWz5dHyk1iJmw90Y976BZIl/mYVgbTtZAJ81oGe/0k5rAe+LDL+Yq6tG28QFOg0QmiQ=="
|
||||||
|
|
||||||
|
params:
|
||||||
|
controller.status.processors: "10"
|
||||||
|
controller.operation.processors: "5"
|
||||||
|
|
||||||
|
server.insecure: true
|
||||||
|
server.enable.gzip: true
|
||||||
|
|
||||||
|
controller:
|
||||||
|
metrics:
|
||||||
|
enabled: false
|
||||||
|
serviceMonitor:
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
resources:
|
||||||
|
limits:
|
||||||
|
# cpu: 500m
|
||||||
|
memory: 2048Mi
|
||||||
|
requests:
|
||||||
|
cpu: 100m
|
||||||
|
memory: 512Mi
|
||||||
|
|
||||||
|
repoServer:
|
||||||
|
metrics:
|
||||||
|
enabled: false
|
||||||
|
serviceMonitor:
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
server:
|
||||||
|
# Rename former https port to grpc, works with istio + insecure
|
||||||
|
service:
|
||||||
|
servicePortHttpsName: grpc
|
||||||
|
metrics:
|
||||||
|
enabled: false
|
||||||
|
serviceMonitor:
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
# redis:
|
||||||
|
# We might want to try to keep redis close to the controller
|
||||||
|
# affinity:
|
||||||
|
|
||||||
|
dex:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
applicationSet:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
notifications:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
# Support for Istio Ingress for ArgoCD
|
||||||
|
istio:
|
||||||
|
# istio.enabled -- Deploy Istio VirtualService to expose ArgoCD
|
||||||
|
enabled: false
|
||||||
|
# istio.gateway -- Name of the Istio gateway to add the VirtualService to
|
||||||
|
gateway: istio-ingress/ingressgateway
|
||||||
|
ipBlocks: []
|
||||||
|
|
||||||
|
argocd-image-updater:
|
||||||
|
enabled: false
|
||||||
|
|
||||||
|
# Unify all ArgoCD pieces under the same argocd namespace
|
||||||
|
fullnameOverride: argocd-image-updater
|
||||||
|
|
||||||
|
config:
|
||||||
|
argocd:
|
||||||
|
plaintext: true
|
||||||
|
|
||||||
|
metrics:
|
||||||
|
enabled: false
|
||||||
|
serviceMonitor:
|
||||||
|
enabled: true
|
||||||
|
|
||||||
|
authScripts:
|
||||||
|
enabled: true
|
||||||
|
scripts:
|
||||||
|
ecr-login.sh: |
|
||||||
|
#!/bin/sh
|
||||||
|
aws ecr --region $AWS_REGION get-authorization-token --output text --query 'authorizationData[].authorizationToken' | base64 -d
|
||||||
|
ecr-public-login.sh: |
|
||||||
|
#!/bin/sh
|
||||||
|
aws ecr-public --region us-east-1 get-authorization-token --output text --query 'authorizationData.authorizationToken' | base64 -d
|
||||||
|
sshConfig:
|
||||||
|
config: |
|
||||||
|
Host *
|
||||||
|
PubkeyAcceptedAlgorithms +ssh-rsa
|
||||||
|
HostkeyAlgorithms +ssh-rsa
|
||||||
|
@ -1,29 +0,0 @@
|
|||||||
apiVersion: v2
|
|
||||||
description: KubeZero ArgoCD - config, branding, image-updater (optional)
|
|
||||||
name: kubezero-argocd
|
|
||||||
version: 0.13.5
|
|
||||||
home: https://kubezero.com
|
|
||||||
icon: https://cdn.zero-downtime.net/assets/kubezero/logo-small-64.png
|
|
||||||
keywords:
|
|
||||||
- kubezero
|
|
||||||
- argocd
|
|
||||||
- argocd-image-updater
|
|
||||||
maintainers:
|
|
||||||
- name: Stefan Reimer
|
|
||||||
email: stefan@zero-downtime.net
|
|
||||||
# Url: https://github.com/argoproj/argo-helm/tree/main/charts
|
|
||||||
dependencies:
|
|
||||||
- name: kubezero-lib
|
|
||||||
version: ">= 0.1.6"
|
|
||||||
repository: https://cdn.zero-downtime.net/charts/
|
|
||||||
- name: argo-cd
|
|
||||||
version: 6.7.3
|
|
||||||
repository: https://argoproj.github.io/argo-helm
|
|
||||||
- name: argocd-apps
|
|
||||||
version: 2.0.0
|
|
||||||
repository: https://argoproj.github.io/argo-helm
|
|
||||||
- name: argocd-image-updater
|
|
||||||
version: 0.9.6
|
|
||||||
repository: https://argoproj.github.io/argo-helm
|
|
||||||
condition: argocd-image-updater.enabled
|
|
||||||
kubeVersion: ">= 1.26.0"
|
|
@ -1,74 +0,0 @@
|
|||||||
# kubezero-argocd
|
|
||||||
|
|
||||||
![Version: 0.13.3](https://img.shields.io/badge/Version-0.13.3-informational?style=flat-square)
|
|
||||||
|
|
||||||
KubeZero ArgoCD - config, branding, image-updater (optional)
|
|
||||||
|
|
||||||
**Homepage:** <https://kubezero.com>
|
|
||||||
|
|
||||||
## Maintainers
|
|
||||||
|
|
||||||
| Name | Email | Url |
|
|
||||||
| ---- | ------ | --- |
|
|
||||||
| Stefan Reimer | <stefan@zero-downtime.net> | |
|
|
||||||
|
|
||||||
## Requirements
|
|
||||||
|
|
||||||
Kubernetes: `>= 1.26.0`
|
|
||||||
|
|
||||||
| Repository | Name | Version |
|
|
||||||
|------------|------|---------|
|
|
||||||
| https://argoproj.github.io/argo-helm | argo-cd | 5.51.4 |
|
|
||||||
| https://argoproj.github.io/argo-helm | argocd-apps | 1.4.1 |
|
|
||||||
| https://argoproj.github.io/argo-helm | argocd-image-updater | 0.9.1 |
|
|
||||||
| https://cdn.zero-downtime.net/charts/ | kubezero-lib | >= 0.1.6 |
|
|
||||||
|
|
||||||
## Values
|
|
||||||
|
|
||||||
| Key | Type | Default | Description |
|
|
||||||
|-----|------|---------|-------------|
|
|
||||||
| argo-cd.applicationSet.enabled | bool | `false` | |
|
|
||||||
| argo-cd.configs.cm."resource.customizations" | string | `"cert-manager.io/Certificate:\n # Lua script for customizing the health status assessment\n health.lua: |\n hs = {}\n if obj.status ~= nil then\n if obj.status.conditions ~= nil then\n for i, condition in ipairs(obj.status.conditions) do\n if condition.type == \"Ready\" and condition.status == \"False\" then\n hs.status = \"Degraded\"\n hs.message = condition.message\n return hs\n end\n if condition.type == \"Ready\" and condition.status == \"True\" then\n hs.status = \"Healthy\"\n hs.message = condition.message\n return hs\n end\n end\n end\n end\n hs.status = \"Progressing\"\n hs.message = \"Waiting for certificate\"\n return hs\n"` | |
|
|
||||||
| argo-cd.configs.cm."timeout.reconciliation" | int | `300` | |
|
|
||||||
| argo-cd.configs.cm."ui.bannercontent" | string | `"KubeZero v1.27 - Release notes"` | |
|
|
||||||
| argo-cd.configs.cm."ui.bannerpermanent" | string | `"true"` | |
|
|
||||||
| argo-cd.configs.cm."ui.bannerposition" | string | `"bottom"` | |
|
|
||||||
| argo-cd.configs.cm."ui.bannerurl" | string | `"https://kubezero.com/releases/v1.27"` | |
|
|
||||||
| argo-cd.configs.cm.url | string | `"https://argocd.example.com"` | |
|
|
||||||
| argo-cd.configs.knownHosts.data.ssh_known_hosts | string | `"bitbucket.org ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBPIQmuzMBuKdWeF4+a2sjSSpBK0iqitSQ+5BM9KhpexuGt20JpTVM7u5BDZngncgrqDMbWdxMWWOGtZ9UgbqgZE=\nbitbucket.org ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIazEu89wgQZ4bqs3d63QSMzYVa0MuJ2e2gKTKqu+UUO\nbitbucket.org ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDQeJzhupRu0u0cdegZIa8e86EG2qOCsIsD1Xw0xSeiPDlCr7kq97NLmMbpKTX6Esc30NuoqEEHCuc7yWtwp8dI76EEEB1VqY9QJq6vk+aySyboD5QF61I/1WeTwu+deCbgKMGbUijeXhtfbxSxm6JwGrXrhBdofTsbKRUsrN1WoNgUa8uqN1Vx6WAJw1JHPhglEGGHea6QICwJOAr/6mrui/oB7pkaWKHj3z7d1IC4KWLtY47elvjbaTlkN04Kc/5LFEirorGYVbt15kAUlqGM65pk6ZBxtaO3+30LVlORZkxOh+LKL/BvbZ/iRNhItLqNyieoQj/uh/7Iv4uyH/cV/0b4WDSd3DptigWq84lJubb9t/DnZlrJazxyDCulTmKdOR7vs9gMTo+uoIrPSb8ScTtvw65+odKAlBj59dhnVp9zd7QUojOpXlL62Aw56U4oO+FALuevvMjiWeavKhJqlR7i5n9srYcrNV7ttmDw7kf/97P5zauIhxcjX+xHv4M=\ngithub.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBEmKSENjQEezOmxkZMy7opKgwFB9nkt5YRrYMjNuG5N87uRgg6CLrbo5wAdT/y6v0mKV0U2w0WZ2YB/++Tpockg=\ngithub.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOMqqnkVzrm0SdG6UOoqKLsabgH5C9okWi0dh2l9GKJl\ngithub.com ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAq2A7hRGmdnm9tUDbO9IDSwBK6TbQa+PXYPCPy6rbTrTtw7PHkccKrpp0yVhp5HdEIcKr6pLlVDBfOLX9QUsyCOV0wzfjIJNlGEYsdlLJizHhbn2mUjvSAHQqZETYP81eFzLQNnPHt4EVVUh7VfDESU84KezmD5QlWpXLmvU31/yMf+Se8xhHTvKSCZIFImWwoG6mbUoWf9nzpIoaSjB+weqqUUmpaaasXVal72J+UX2B+2RPW3RcT0eOzQgqlJL3RKrTJvdsjE3JEAvGq3lGHSZXy28G3skua2SmVi/w4yCE6gbODqnTWlg7+wC604ydGXA8VJiS5ap43JXiUFFAaQ==\ngitlab.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBFSMqzJeV9rUzU4kWitGjeR4PWSa29SPqJ1fVkhtj3Hw9xjLVXVYrU9QlYWrOLXBpQ6KWjbjTDTdDkoohFzgbEY=\ngitlab.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAfuCHKVTjquxvt6CM6tdG4SLp1Btn/nOeHHE5UOzRdf\ngitlab.com ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCsj2bNKTBSpIYDEGk9KxsGh3mySTRgMtXL583qmBpzeQ+jqCMRgBqB98u3z++J1sKlXHWfM9dyhSevkMwSbhoR8XIq/U0tCNyokEi/ueaBMCvbcTHhO7FcwzY92WK4Yt0aGROY5qX2UKSeOvuP4D6TPqKF1onrSzH9bx9XUf2lEdWT/ia1NEKjunUqu1xOB/StKDHMoX4/OKyIzuS0q/T1zOATthvasJFoPrAjkohTyaDUz2LN5JoH839hViyEG82yB+MjcFV5MU3N1l1QL3cVUCh93xSaua1N85qivl+siMkPGbO5xR/En4iEY6K2XPASUEMaieWVNTRCtJ4S8H+9\ngit.zero-downtime.net ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC8YdJ4YcOK7A0K7qOWsRjCS+wHTStXRcwBe7gjG43HPSNijiCKoGf/c+tfNsRhyouawg7Law6M6ahmS/jKWBpznRIM+OdOFVSuhnK/nr6h6wG3/ZfdLicyAPvx1/STGY/Fc6/zXA88i/9PV+g84gSVmhf3fGY92wokiASiu9DU4T9dT1gIkdyOX6fbMi1/mMKLSrHnAQcjyasYDvw9ISCJ95EoSwbj7O4c+7jo9fxYvdCfZZZAEZGozTRLAAO0AnjVcRah7bZV/jfHJuhOipV/TB7UVAhlVv1dfGV7hoTp9UKtKZFJF4cjIrSGxqQA/mdhSdLgkepK7yc4Jp2xGnaarhY29DfqsQqop+ugFpTbj7Xy5Rco07mXc6XssbAZhI1xtCOX20N4PufBuYippCK5AE6AiAyVtJmvfGQk4HP+TjOyhFo7PZm3wc9Hym7IBBVC0Sl30K8ddufkAgHwNGvvu1ZmD9ZWaMOXJDHBCZGMMr16QREZwVtZTwMEQalc7/yqmuqMhmcJIfs/GA2Lt91y+pq9C8XyeUL0VFPch0vkcLSRe3ghMZpRFJ/ht307xPcLzgTJqN6oQtNNDzSQglSEjwhge2K4GyWcIh+oGsWxWz5dHyk1iJmw90Y976BZIl/mYVgbTtZAJ81oGe/0k5rAe+LDL+Yq6tG28QFOg0QmiQ==\n"` | |
|
|
||||||
| argo-cd.configs.params."controller.operation.processors" | string | `"5"` | |
|
|
||||||
| argo-cd.configs.params."controller.status.processors" | string | `"10"` | |
|
|
||||||
| argo-cd.configs.params."server.enable.gzip" | bool | `true` | |
|
|
||||||
| argo-cd.configs.params."server.insecure" | bool | `true` | |
|
|
||||||
| argo-cd.configs.secret.createSecret | bool | `false` | |
|
|
||||||
| argo-cd.configs.styles | string | `".sidebar__logo img { content: url(https://cdn.zero-downtime.net/assets/kubezero/logo-small-64.png); }\n.sidebar__logo__text-logo { height: 0em; }\n.sidebar { background: linear-gradient(to bottom, #6A4D79, #493558, #2D1B30, #0D0711); }\n"` | |
|
|
||||||
| argo-cd.controller.metrics.enabled | bool | `false` | |
|
|
||||||
| argo-cd.controller.metrics.serviceMonitor.enabled | bool | `true` | |
|
|
||||||
| argo-cd.controller.resources.requests.cpu | string | `"100m"` | |
|
|
||||||
| argo-cd.controller.resources.requests.memory | string | `"256Mi"` | |
|
|
||||||
| argo-cd.dex.enabled | bool | `false` | |
|
|
||||||
| argo-cd.global.logging.format | string | `"json"` | |
|
|
||||||
| argo-cd.notifications.enabled | bool | `false` | |
|
|
||||||
| argo-cd.repoServer.metrics.enabled | bool | `false` | |
|
|
||||||
| argo-cd.repoServer.metrics.serviceMonitor.enabled | bool | `true` | |
|
|
||||||
| argo-cd.server.metrics.enabled | bool | `false` | |
|
|
||||||
| argo-cd.server.metrics.serviceMonitor.enabled | bool | `true` | |
|
|
||||||
| argo-cd.server.service.servicePortHttpsName | string | `"grpc"` | |
|
|
||||||
| argocd-apps.applications | list | `[]` | |
|
|
||||||
| argocd-apps.projects | list | `[]` | |
|
|
||||||
| argocd-image-updater.authScripts.enabled | bool | `true` | |
|
|
||||||
| argocd-image-updater.authScripts.scripts."ecr-login.sh" | string | `"#!/bin/sh\naws ecr --region $AWS_REGION get-authorization-token --output text --query 'authorizationData[].authorizationToken' | base64 -d\n"` | |
|
|
||||||
| argocd-image-updater.authScripts.scripts."ecr-public-login.sh" | string | `"#!/bin/sh\naws ecr-public --region us-east-1 get-authorization-token --output text --query 'authorizationData.authorizationToken' | base64 -d\n"` | |
|
|
||||||
| argocd-image-updater.config.argocd.plaintext | bool | `true` | |
|
|
||||||
| argocd-image-updater.enabled | bool | `false` | |
|
|
||||||
| argocd-image-updater.fullnameOverride | string | `"argocd-image-updater"` | |
|
|
||||||
| argocd-image-updater.metrics.enabled | bool | `false` | |
|
|
||||||
| argocd-image-updater.metrics.serviceMonitor.enabled | bool | `true` | |
|
|
||||||
| argocd-image-updater.sshConfig.config | string | `"Host *\n PubkeyAcceptedAlgorithms +ssh-rsa\n HostkeyAlgorithms +ssh-rsa\n"` | |
|
|
||||||
| istio.enabled | bool | `false` | Deploy Istio VirtualService to expose ArgoCD |
|
|
||||||
| istio.gateway | string | `"istio-ingress/ingressgateway"` | Name of the Istio gateway to add the VirtualService to |
|
|
||||||
| istio.ipBlocks | list | `[]` | |
|
|
||||||
|
|
||||||
## Resources
|
|
||||||
- https://argoproj.github.io/argo-cd/operator-manual/metrics/
|
|
||||||
- https://raw.githubusercontent.com/argoproj/argo-cd/master/examples/dashboard.json
|
|
@ -1,20 +0,0 @@
|
|||||||
{{ template "chart.header" . }}
|
|
||||||
{{ template "chart.deprecationWarning" . }}
|
|
||||||
|
|
||||||
{{ template "chart.versionBadge" . }}{{ template "chart.typeBadge" . }}{{ template "chart.appVersionBadge" . }}
|
|
||||||
|
|
||||||
{{ template "chart.description" . }}
|
|
||||||
|
|
||||||
{{ template "chart.homepageLine" . }}
|
|
||||||
|
|
||||||
{{ template "chart.maintainersSection" . }}
|
|
||||||
|
|
||||||
{{ template "chart.sourcesSection" . }}
|
|
||||||
|
|
||||||
{{ template "chart.requirementsSection" . }}
|
|
||||||
|
|
||||||
{{ template "chart.valuesSection" . }}
|
|
||||||
|
|
||||||
## Resources
|
|
||||||
- https://argoproj.github.io/argo-cd/operator-manual/metrics/
|
|
||||||
- https://raw.githubusercontent.com/argoproj/argo-cd/master/examples/dashboard.json
|
|
@ -1,9 +0,0 @@
|
|||||||
configmap: grafana-dashboards
|
|
||||||
gzip: true
|
|
||||||
condition: 'index .Values "argo-cd" "controller" "metrics" "enabled"'
|
|
||||||
folder: KubeZero
|
|
||||||
dashboards:
|
|
||||||
- name: ArgoCD
|
|
||||||
url: https://grafana.com/api/dashboards/14584/revisions/1/download
|
|
||||||
tags:
|
|
||||||
- ArgoCD
|
|
File diff suppressed because one or more lines are too long
@ -1,28 +0,0 @@
|
|||||||
{{- if .Values.istio.enabled }}
|
|
||||||
{{- if .Values.istio.ipBlocks }}
|
|
||||||
apiVersion: security.istio.io/v1beta1
|
|
||||||
kind: AuthorizationPolicy
|
|
||||||
metadata:
|
|
||||||
name: argocd-deny-not-in-ipblocks
|
|
||||||
namespace: istio-system
|
|
||||||
labels:
|
|
||||||
{{- include "kubezero-lib.labels" . | nindent 4 }}
|
|
||||||
spec:
|
|
||||||
selector:
|
|
||||||
matchLabels:
|
|
||||||
app: istio-ingressgateway
|
|
||||||
action: DENY
|
|
||||||
rules:
|
|
||||||
- from:
|
|
||||||
- source:
|
|
||||||
notIpBlocks:
|
|
||||||
{{- toYaml .Values.istio.ipBlocks | nindent 8 }}
|
|
||||||
to:
|
|
||||||
- operation:
|
|
||||||
hosts: [{{ index .Values "argo-cd" "configs" "cm" "url" | quote }}]
|
|
||||||
when:
|
|
||||||
- key: connection.sni
|
|
||||||
values:
|
|
||||||
- '*'
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
@ -1,31 +0,0 @@
|
|||||||
{{- if .Values.istio.enabled }}
|
|
||||||
apiVersion: networking.istio.io/v1alpha3
|
|
||||||
kind: VirtualService
|
|
||||||
metadata:
|
|
||||||
name: argocd-server
|
|
||||||
namespace: {{ $.Release.Namespace }}
|
|
||||||
labels:
|
|
||||||
{{- include "kubezero-lib.labels" . | nindent 4 }}
|
|
||||||
spec:
|
|
||||||
gateways:
|
|
||||||
- {{ .Values.istio.gateway }}
|
|
||||||
hosts:
|
|
||||||
- {{ get (urlParse (index .Values "argo-cd" "configs" "cm" "url")) "host" }}
|
|
||||||
http:
|
|
||||||
- name: grpc
|
|
||||||
match:
|
|
||||||
- headers:
|
|
||||||
user-agent:
|
|
||||||
prefix: argocd-client
|
|
||||||
route:
|
|
||||||
- destination:
|
|
||||||
host: argocd-server
|
|
||||||
port:
|
|
||||||
number: 443
|
|
||||||
- name: http
|
|
||||||
route:
|
|
||||||
- destination:
|
|
||||||
host: argocd-server
|
|
||||||
port:
|
|
||||||
number: 80
|
|
||||||
{{- end }}
|
|
@ -1,10 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
|
|
||||||
. ../../scripts/lib-update.sh
|
|
||||||
|
|
||||||
update_helm
|
|
||||||
|
|
||||||
# Create ZDT dashboard configmap
|
|
||||||
../kubezero-metrics/sync_grafana_dashboards.py dashboards.yaml templates/grafana-dashboards.yaml
|
|
||||||
|
|
||||||
update_docs
|
|
@ -1,162 +0,0 @@
|
|||||||
# Support for Istio Ingress for ArgoCD
|
|
||||||
istio:
|
|
||||||
# istio.enabled -- Deploy Istio VirtualService to expose ArgoCD
|
|
||||||
enabled: false
|
|
||||||
# istio.gateway -- Name of the Istio gateway to add the VirtualService to
|
|
||||||
gateway: istio-ingress/ingressgateway
|
|
||||||
ipBlocks: []
|
|
||||||
|
|
||||||
argocd-apps:
|
|
||||||
projects: []
|
|
||||||
applications: []
|
|
||||||
|
|
||||||
argo-cd:
|
|
||||||
#configs:
|
|
||||||
# secret:
|
|
||||||
# `htpasswd -nbBC 10 "" $ARGO_PWD | tr -d ':\n' | sed 's/$2y/$2a/'`
|
|
||||||
# argocdServerAdminPassword: "$2a$10$ivKzaXVxMqdeDSfS3nqi1Od3iDbnL7oXrixzDfZFRHlXHnAG6LydG"
|
|
||||||
# argocdServerAdminPasswordMtime: "2020-04-24T15:33:09BST"
|
|
||||||
|
|
||||||
global:
|
|
||||||
logging:
|
|
||||||
format: json
|
|
||||||
# image:
|
|
||||||
# tag: v2.1.6
|
|
||||||
|
|
||||||
configs:
|
|
||||||
styles: |
|
|
||||||
.sidebar__logo img { content: url(https://cdn.zero-downtime.net/assets/kubezero/logo-small-64.png); }
|
|
||||||
.sidebar__logo__text-logo { height: 0em; }
|
|
||||||
.sidebar { background: linear-gradient(to bottom, #6A4D79, #493558, #2D1B30, #0D0711); }
|
|
||||||
|
|
||||||
cm:
|
|
||||||
ui.bannercontent: "KubeZero v1.27 - Release notes"
|
|
||||||
ui.bannerurl: "https://kubezero.com/releases/v1.27"
|
|
||||||
ui.bannerpermanent: "true"
|
|
||||||
ui.bannerposition: "bottom"
|
|
||||||
|
|
||||||
# argo-cd.server.config.url -- ArgoCD URL being exposed via Istio
|
|
||||||
url: https://argocd.example.com
|
|
||||||
|
|
||||||
timeout.reconciliation: 300
|
|
||||||
|
|
||||||
resource.customizations: |
|
|
||||||
cert-manager.io/Certificate:
|
|
||||||
# Lua script for customizing the health status assessment
|
|
||||||
health.lua: |
|
|
||||||
hs = {}
|
|
||||||
if obj.status ~= nil then
|
|
||||||
if obj.status.conditions ~= nil then
|
|
||||||
for i, condition in ipairs(obj.status.conditions) do
|
|
||||||
if condition.type == "Ready" and condition.status == "False" then
|
|
||||||
hs.status = "Degraded"
|
|
||||||
hs.message = condition.message
|
|
||||||
return hs
|
|
||||||
end
|
|
||||||
if condition.type == "Ready" and condition.status == "True" then
|
|
||||||
hs.status = "Healthy"
|
|
||||||
hs.message = condition.message
|
|
||||||
return hs
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
hs.status = "Progressing"
|
|
||||||
hs.message = "Waiting for certificate"
|
|
||||||
return hs
|
|
||||||
|
|
||||||
secret:
|
|
||||||
createSecret: false
|
|
||||||
|
|
||||||
knownHosts:
|
|
||||||
data:
|
|
||||||
ssh_known_hosts: |
|
|
||||||
bitbucket.org ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBPIQmuzMBuKdWeF4+a2sjSSpBK0iqitSQ+5BM9KhpexuGt20JpTVM7u5BDZngncgrqDMbWdxMWWOGtZ9UgbqgZE=
|
|
||||||
bitbucket.org ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIIazEu89wgQZ4bqs3d63QSMzYVa0MuJ2e2gKTKqu+UUO
|
|
||||||
bitbucket.org ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABgQDQeJzhupRu0u0cdegZIa8e86EG2qOCsIsD1Xw0xSeiPDlCr7kq97NLmMbpKTX6Esc30NuoqEEHCuc7yWtwp8dI76EEEB1VqY9QJq6vk+aySyboD5QF61I/1WeTwu+deCbgKMGbUijeXhtfbxSxm6JwGrXrhBdofTsbKRUsrN1WoNgUa8uqN1Vx6WAJw1JHPhglEGGHea6QICwJOAr/6mrui/oB7pkaWKHj3z7d1IC4KWLtY47elvjbaTlkN04Kc/5LFEirorGYVbt15kAUlqGM65pk6ZBxtaO3+30LVlORZkxOh+LKL/BvbZ/iRNhItLqNyieoQj/uh/7Iv4uyH/cV/0b4WDSd3DptigWq84lJubb9t/DnZlrJazxyDCulTmKdOR7vs9gMTo+uoIrPSb8ScTtvw65+odKAlBj59dhnVp9zd7QUojOpXlL62Aw56U4oO+FALuevvMjiWeavKhJqlR7i5n9srYcrNV7ttmDw7kf/97P5zauIhxcjX+xHv4M=
|
|
||||||
github.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBEmKSENjQEezOmxkZMy7opKgwFB9nkt5YRrYMjNuG5N87uRgg6CLrbo5wAdT/y6v0mKV0U2w0WZ2YB/++Tpockg=
|
|
||||||
github.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIOMqqnkVzrm0SdG6UOoqKLsabgH5C9okWi0dh2l9GKJl
|
|
||||||
github.com ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEAq2A7hRGmdnm9tUDbO9IDSwBK6TbQa+PXYPCPy6rbTrTtw7PHkccKrpp0yVhp5HdEIcKr6pLlVDBfOLX9QUsyCOV0wzfjIJNlGEYsdlLJizHhbn2mUjvSAHQqZETYP81eFzLQNnPHt4EVVUh7VfDESU84KezmD5QlWpXLmvU31/yMf+Se8xhHTvKSCZIFImWwoG6mbUoWf9nzpIoaSjB+weqqUUmpaaasXVal72J+UX2B+2RPW3RcT0eOzQgqlJL3RKrTJvdsjE3JEAvGq3lGHSZXy28G3skua2SmVi/w4yCE6gbODqnTWlg7+wC604ydGXA8VJiS5ap43JXiUFFAaQ==
|
|
||||||
gitlab.com ecdsa-sha2-nistp256 AAAAE2VjZHNhLXNoYTItbmlzdHAyNTYAAAAIbmlzdHAyNTYAAABBBFSMqzJeV9rUzU4kWitGjeR4PWSa29SPqJ1fVkhtj3Hw9xjLVXVYrU9QlYWrOLXBpQ6KWjbjTDTdDkoohFzgbEY=
|
|
||||||
gitlab.com ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIAfuCHKVTjquxvt6CM6tdG4SLp1Btn/nOeHHE5UOzRdf
|
|
||||||
gitlab.com ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCsj2bNKTBSpIYDEGk9KxsGh3mySTRgMtXL583qmBpzeQ+jqCMRgBqB98u3z++J1sKlXHWfM9dyhSevkMwSbhoR8XIq/U0tCNyokEi/ueaBMCvbcTHhO7FcwzY92WK4Yt0aGROY5qX2UKSeOvuP4D6TPqKF1onrSzH9bx9XUf2lEdWT/ia1NEKjunUqu1xOB/StKDHMoX4/OKyIzuS0q/T1zOATthvasJFoPrAjkohTyaDUz2LN5JoH839hViyEG82yB+MjcFV5MU3N1l1QL3cVUCh93xSaua1N85qivl+siMkPGbO5xR/En4iEY6K2XPASUEMaieWVNTRCtJ4S8H+9
|
|
||||||
git.zero-downtime.net ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAACAQC8YdJ4YcOK7A0K7qOWsRjCS+wHTStXRcwBe7gjG43HPSNijiCKoGf/c+tfNsRhyouawg7Law6M6ahmS/jKWBpznRIM+OdOFVSuhnK/nr6h6wG3/ZfdLicyAPvx1/STGY/Fc6/zXA88i/9PV+g84gSVmhf3fGY92wokiASiu9DU4T9dT1gIkdyOX6fbMi1/mMKLSrHnAQcjyasYDvw9ISCJ95EoSwbj7O4c+7jo9fxYvdCfZZZAEZGozTRLAAO0AnjVcRah7bZV/jfHJuhOipV/TB7UVAhlVv1dfGV7hoTp9UKtKZFJF4cjIrSGxqQA/mdhSdLgkepK7yc4Jp2xGnaarhY29DfqsQqop+ugFpTbj7Xy5Rco07mXc6XssbAZhI1xtCOX20N4PufBuYippCK5AE6AiAyVtJmvfGQk4HP+TjOyhFo7PZm3wc9Hym7IBBVC0Sl30K8ddufkAgHwNGvvu1ZmD9ZWaMOXJDHBCZGMMr16QREZwVtZTwMEQalc7/yqmuqMhmcJIfs/GA2Lt91y+pq9C8XyeUL0VFPch0vkcLSRe3ghMZpRFJ/ht307xPcLzgTJqN6oQtNNDzSQglSEjwhge2K4GyWcIh+oGsWxWz5dHyk1iJmw90Y976BZIl/mYVgbTtZAJ81oGe/0k5rAe+LDL+Yq6tG28QFOg0QmiQ==
|
|
||||||
|
|
||||||
params:
|
|
||||||
controller.status.processors: "10"
|
|
||||||
controller.operation.processors: "5"
|
|
||||||
|
|
||||||
server.insecure: true
|
|
||||||
server.enable.gzip: true
|
|
||||||
|
|
||||||
controller:
|
|
||||||
metrics:
|
|
||||||
enabled: false
|
|
||||||
serviceMonitor:
|
|
||||||
enabled: true
|
|
||||||
|
|
||||||
resources:
|
|
||||||
limits:
|
|
||||||
# cpu: 500m
|
|
||||||
memory: 2048Mi
|
|
||||||
requests:
|
|
||||||
cpu: 100m
|
|
||||||
memory: 512Mi
|
|
||||||
|
|
||||||
repoServer:
|
|
||||||
metrics:
|
|
||||||
enabled: false
|
|
||||||
serviceMonitor:
|
|
||||||
enabled: true
|
|
||||||
|
|
||||||
server:
|
|
||||||
# Rename former https port to grpc, works with istio + insecure
|
|
||||||
service:
|
|
||||||
servicePortHttpsName: grpc
|
|
||||||
metrics:
|
|
||||||
enabled: false
|
|
||||||
serviceMonitor:
|
|
||||||
enabled: true
|
|
||||||
|
|
||||||
# redis:
|
|
||||||
# We might want to try to keep redis close to the controller
|
|
||||||
# affinity:
|
|
||||||
|
|
||||||
dex:
|
|
||||||
enabled: false
|
|
||||||
|
|
||||||
applicationSet:
|
|
||||||
enabled: false
|
|
||||||
|
|
||||||
notifications:
|
|
||||||
enabled: false
|
|
||||||
|
|
||||||
argocd-image-updater:
|
|
||||||
enabled: false
|
|
||||||
|
|
||||||
# Unify all ArgoCD pieces under the same argocd namespace
|
|
||||||
fullnameOverride: argocd-image-updater
|
|
||||||
|
|
||||||
config:
|
|
||||||
argocd:
|
|
||||||
plaintext: true
|
|
||||||
|
|
||||||
metrics:
|
|
||||||
enabled: false
|
|
||||||
serviceMonitor:
|
|
||||||
enabled: true
|
|
||||||
|
|
||||||
authScripts:
|
|
||||||
enabled: true
|
|
||||||
scripts:
|
|
||||||
ecr-login.sh: |
|
|
||||||
#!/bin/sh
|
|
||||||
aws ecr --region $AWS_REGION get-authorization-token --output text --query 'authorizationData[].authorizationToken' | base64 -d
|
|
||||||
ecr-public-login.sh: |
|
|
||||||
#!/bin/sh
|
|
||||||
aws ecr-public --region us-east-1 get-authorization-token --output text --query 'authorizationData.authorizationToken' | base64 -d
|
|
||||||
sshConfig:
|
|
||||||
config: |
|
|
||||||
Host *
|
|
||||||
PubkeyAcceptedAlgorithms +ssh-rsa
|
|
||||||
HostkeyAlgorithms +ssh-rsa
|
|
@ -1,6 +1,6 @@
|
|||||||
# kubezero-network
|
# kubezero-network
|
||||||
|
|
||||||
![Version: 0.5.0](https://img.shields.io/badge/Version-0.5.0-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square)
|
![Version: 0.5.1](https://img.shields.io/badge/Version-0.5.1-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square)
|
||||||
|
|
||||||
KubeZero umbrella chart for all things network
|
KubeZero umbrella chart for all things network
|
||||||
|
|
||||||
@ -19,8 +19,8 @@ Kubernetes: `>= 1.26.0`
|
|||||||
| Repository | Name | Version |
|
| Repository | Name | Version |
|
||||||
|------------|------|---------|
|
|------------|------|---------|
|
||||||
| https://cdn.zero-downtime.net/charts/ | kubezero-lib | >= 0.1.6 |
|
| https://cdn.zero-downtime.net/charts/ | kubezero-lib | >= 0.1.6 |
|
||||||
| https://helm.cilium.io/ | cilium | 1.15.2 |
|
| https://helm.cilium.io/ | cilium | 1.15.3 |
|
||||||
| https://metallb.github.io/metallb | metallb | 0.14.3 |
|
| https://metallb.github.io/metallb | metallb | 0.14.4 |
|
||||||
|
|
||||||
## Values
|
## Values
|
||||||
|
|
||||||
|
@ -1,3 +1,4 @@
|
|||||||
|
{{- if .Values.k8up.enabled }}
|
||||||
---
|
---
|
||||||
apiVersion: apiextensions.k8s.io/v1
|
apiVersion: apiextensions.k8s.io/v1
|
||||||
kind: CustomResourceDefinition
|
kind: CustomResourceDefinition
|
||||||
@ -14420,3 +14421,4 @@ spec:
|
|||||||
storage: true
|
storage: true
|
||||||
subresources:
|
subresources:
|
||||||
status: {}
|
status: {}
|
||||||
|
{{- end }}
|
@ -1,103 +0,0 @@
|
|||||||
# RBAC file for the snapshot controller.
|
|
||||||
#
|
|
||||||
# The snapshot controller implements the control loop for CSI snapshot functionality.
|
|
||||||
# It should be installed as part of the base Kubernetes distribution in an appropriate
|
|
||||||
# namespace for components implementing base system functionality. For installing with
|
|
||||||
# Vanilla Kubernetes, kube-system makes sense for the namespace.
|
|
||||||
|
|
||||||
---
|
|
||||||
apiVersion: v1
|
|
||||||
kind: ServiceAccount
|
|
||||||
metadata:
|
|
||||||
name: snapshot-controller
|
|
||||||
namespace: kube-system
|
|
||||||
|
|
||||||
---
|
|
||||||
kind: ClusterRole
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
metadata:
|
|
||||||
name: snapshot-controller-runner
|
|
||||||
rules:
|
|
||||||
- apiGroups: [""]
|
|
||||||
resources: ["persistentvolumes"]
|
|
||||||
verbs: ["get", "list", "watch"]
|
|
||||||
- apiGroups: [""]
|
|
||||||
resources: ["persistentvolumeclaims"]
|
|
||||||
verbs: ["get", "list", "watch", "update"]
|
|
||||||
- apiGroups: [""]
|
|
||||||
resources: ["events"]
|
|
||||||
verbs: ["list", "watch", "create", "update", "patch"]
|
|
||||||
- apiGroups: ["snapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumesnapshotclasses"]
|
|
||||||
verbs: ["get", "list", "watch"]
|
|
||||||
- apiGroups: ["snapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumesnapshotcontents"]
|
|
||||||
verbs: ["create", "get", "list", "watch", "update", "delete", "patch"]
|
|
||||||
- apiGroups: ["snapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumesnapshotcontents/status"]
|
|
||||||
verbs: ["patch"]
|
|
||||||
- apiGroups: ["snapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumesnapshots"]
|
|
||||||
verbs: ["get", "list", "watch", "update", "patch", "delete"]
|
|
||||||
- apiGroups: ["snapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumesnapshots/status"]
|
|
||||||
verbs: ["update", "patch"]
|
|
||||||
|
|
||||||
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumegroupsnapshotclasses"]
|
|
||||||
verbs: ["get", "list", "watch"]
|
|
||||||
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumegroupsnapshotcontents"]
|
|
||||||
verbs: ["create", "get", "list", "watch", "update", "delete", "patch"]
|
|
||||||
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumegroupsnapshotcontents/status"]
|
|
||||||
verbs: ["patch"]
|
|
||||||
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumegroupsnapshots"]
|
|
||||||
verbs: ["get", "list", "watch", "update", "patch"]
|
|
||||||
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
|
||||||
resources: ["volumegroupsnapshots/status"]
|
|
||||||
verbs: ["update", "patch"]
|
|
||||||
|
|
||||||
# Enable this RBAC rule only when using distributed snapshotting, i.e. when the enable-distributed-snapshotting flag is set to true
|
|
||||||
# - apiGroups: [""]
|
|
||||||
# resources: ["nodes"]
|
|
||||||
# verbs: ["get", "list", "watch"]
|
|
||||||
---
|
|
||||||
kind: ClusterRoleBinding
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
metadata:
|
|
||||||
name: snapshot-controller-role
|
|
||||||
subjects:
|
|
||||||
- kind: ServiceAccount
|
|
||||||
name: snapshot-controller
|
|
||||||
namespace: kube-system
|
|
||||||
roleRef:
|
|
||||||
kind: ClusterRole
|
|
||||||
name: snapshot-controller-runner
|
|
||||||
apiGroup: rbac.authorization.k8s.io
|
|
||||||
|
|
||||||
---
|
|
||||||
kind: Role
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
metadata:
|
|
||||||
name: snapshot-controller-leaderelection
|
|
||||||
namespace: kube-system
|
|
||||||
rules:
|
|
||||||
- apiGroups: ["coordination.k8s.io"]
|
|
||||||
resources: ["leases"]
|
|
||||||
verbs: ["get", "watch", "list", "delete", "update", "create"]
|
|
||||||
|
|
||||||
---
|
|
||||||
kind: RoleBinding
|
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
|
||||||
metadata:
|
|
||||||
name: snapshot-controller-leaderelection
|
|
||||||
namespace: kube-system
|
|
||||||
subjects:
|
|
||||||
- kind: ServiceAccount
|
|
||||||
name: snapshot-controller
|
|
||||||
roleRef:
|
|
||||||
kind: Role
|
|
||||||
name: snapshot-controller-leaderelection
|
|
||||||
apiGroup: rbac.authorization.k8s.io
|
|
@ -6,6 +6,7 @@
|
|||||||
# namespace for components implementing base system functionality. For installing with
|
# namespace for components implementing base system functionality. For installing with
|
||||||
# Vanilla Kubernetes, kube-system makes sense for the namespace.
|
# Vanilla Kubernetes, kube-system makes sense for the namespace.
|
||||||
|
|
||||||
|
---
|
||||||
apiVersion: v1
|
apiVersion: v1
|
||||||
kind: ServiceAccount
|
kind: ServiceAccount
|
||||||
metadata:
|
metadata:
|
||||||
@ -16,7 +17,6 @@ metadata:
|
|||||||
kind: ClusterRole
|
kind: ClusterRole
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
metadata:
|
metadata:
|
||||||
# rename if there are conflicts
|
|
||||||
name: snapshot-controller-runner
|
name: snapshot-controller-runner
|
||||||
rules:
|
rules:
|
||||||
- apiGroups: [""]
|
- apiGroups: [""]
|
||||||
@ -39,15 +39,31 @@ rules:
|
|||||||
verbs: ["patch"]
|
verbs: ["patch"]
|
||||||
- apiGroups: ["snapshot.storage.k8s.io"]
|
- apiGroups: ["snapshot.storage.k8s.io"]
|
||||||
resources: ["volumesnapshots"]
|
resources: ["volumesnapshots"]
|
||||||
verbs: ["get", "list", "watch", "update", "patch"]
|
verbs: ["get", "list", "watch", "update", "patch", "delete"]
|
||||||
- apiGroups: ["snapshot.storage.k8s.io"]
|
- apiGroups: ["snapshot.storage.k8s.io"]
|
||||||
resources: ["volumesnapshots/status"]
|
resources: ["volumesnapshots/status"]
|
||||||
verbs: ["update", "patch"]
|
verbs: ["update", "patch"]
|
||||||
|
|
||||||
|
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
||||||
|
resources: ["volumegroupsnapshotclasses"]
|
||||||
|
verbs: ["get", "list", "watch"]
|
||||||
|
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
||||||
|
resources: ["volumegroupsnapshotcontents"]
|
||||||
|
verbs: ["create", "get", "list", "watch", "update", "delete", "patch"]
|
||||||
|
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
||||||
|
resources: ["volumegroupsnapshotcontents/status"]
|
||||||
|
verbs: ["patch"]
|
||||||
|
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
||||||
|
resources: ["volumegroupsnapshots"]
|
||||||
|
verbs: ["get", "list", "watch", "update", "patch"]
|
||||||
|
- apiGroups: ["groupsnapshot.storage.k8s.io"]
|
||||||
|
resources: ["volumegroupsnapshots/status"]
|
||||||
|
verbs: ["update", "patch"]
|
||||||
|
|
||||||
# Enable this RBAC rule only when using distributed snapshotting, i.e. when the enable-distributed-snapshotting flag is set to true
|
# Enable this RBAC rule only when using distributed snapshotting, i.e. when the enable-distributed-snapshotting flag is set to true
|
||||||
# - apiGroups: [""]
|
# - apiGroups: [""]
|
||||||
# resources: ["nodes"]
|
# resources: ["nodes"]
|
||||||
# verbs: ["get", "list", "watch"]
|
# verbs: ["get", "list", "watch"]
|
||||||
|
|
||||||
---
|
---
|
||||||
kind: ClusterRoleBinding
|
kind: ClusterRoleBinding
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
@ -59,7 +75,6 @@ subjects:
|
|||||||
namespace: kube-system
|
namespace: kube-system
|
||||||
roleRef:
|
roleRef:
|
||||||
kind: ClusterRole
|
kind: ClusterRole
|
||||||
# change the name also here if the ClusterRole gets renamed
|
|
||||||
name: snapshot-controller-runner
|
name: snapshot-controller-runner
|
||||||
apiGroup: rbac.authorization.k8s.io
|
apiGroup: rbac.authorization.k8s.io
|
||||||
|
|
||||||
@ -67,8 +82,8 @@ roleRef:
|
|||||||
kind: Role
|
kind: Role
|
||||||
apiVersion: rbac.authorization.k8s.io/v1
|
apiVersion: rbac.authorization.k8s.io/v1
|
||||||
metadata:
|
metadata:
|
||||||
namespace: kube-system
|
|
||||||
name: snapshot-controller-leaderelection
|
name: snapshot-controller-leaderelection
|
||||||
|
namespace: kube-system
|
||||||
rules:
|
rules:
|
||||||
- apiGroups: ["coordination.k8s.io"]
|
- apiGroups: ["coordination.k8s.io"]
|
||||||
resources: ["leases"]
|
resources: ["leases"]
|
||||||
@ -83,7 +98,6 @@ metadata:
|
|||||||
subjects:
|
subjects:
|
||||||
- kind: ServiceAccount
|
- kind: ServiceAccount
|
||||||
name: snapshot-controller
|
name: snapshot-controller
|
||||||
namespace: kube-system
|
|
||||||
roleRef:
|
roleRef:
|
||||||
kind: Role
|
kind: Role
|
||||||
name: snapshot-controller-leaderelection
|
name: snapshot-controller-leaderelection
|
||||||
|
@ -15,7 +15,12 @@ patch_chart lvm-localpv
|
|||||||
patch_chart gemini
|
patch_chart gemini
|
||||||
|
|
||||||
# snapshotter
|
# snapshotter
|
||||||
# https://raw.githubusercontent.com/kubernetes-csi/external-snapshotter/master/deploy/kubernetes/snapshot-controller/rbac-snapshot-controller.yaml
|
_f="templates/snapshot-controller/rbac.yaml"
|
||||||
|
echo "{{- if .Values.snapshotController.enabled }}" > $_f
|
||||||
|
curl -L -s https://raw.githubusercontent.com/kubernetes-csi/external-snapshotter/master/deploy/kubernetes/snapshot-controller/rbac-snapshot-controller.yaml >> $_f
|
||||||
|
echo "{{- end }}" >> $_f
|
||||||
|
|
||||||
|
# our controller.yaml is based on:
|
||||||
# https://raw.githubusercontent.com/kubernetes-csi/external-snapshotter/master/deploy/kubernetes/snapshot-controller/setup-snapshot-controller.yaml
|
# https://raw.githubusercontent.com/kubernetes-csi/external-snapshotter/master/deploy/kubernetes/snapshot-controller/setup-snapshot-controller.yaml
|
||||||
|
|
||||||
for crd in volumesnapshotclasses volumesnapshotcontents volumesnapshots; do
|
for crd in volumesnapshotclasses volumesnapshotcontents volumesnapshots; do
|
||||||
@ -28,7 +33,11 @@ done
|
|||||||
|
|
||||||
# k8up - CRDs
|
# k8up - CRDs
|
||||||
VERSION=$(yq eval '.dependencies[] | select(.name=="k8up") | .version' Chart.yaml)
|
VERSION=$(yq eval '.dependencies[] | select(.name=="k8up") | .version' Chart.yaml)
|
||||||
curl -L -s -o crds/k8up.yaml https://github.com/k8up-io/k8up/releases/download/k8up-${VERSION}/k8up-crd.yaml
|
|
||||||
|
_f="templates/k8up/crds.yaml"
|
||||||
|
echo "{{- if .Values.k8up.enabled }}" > $_f
|
||||||
|
curl -L -s https://github.com/k8up-io/k8up/releases/download/k8up-${VERSION}/k8up-crd.yaml >> $_f
|
||||||
|
echo "{{- end }}" >> $_f
|
||||||
|
|
||||||
# Metrics
|
# Metrics
|
||||||
cd jsonnet
|
cd jsonnet
|
||||||
|
@ -25,6 +25,7 @@ argo-cd:
|
|||||||
{{- end }}
|
{{- end }}
|
||||||
|
|
||||||
argocd-apps:
|
argocd-apps:
|
||||||
|
enabled: {{ default "false" (index .Values "argo" "argo-cd" "enabled") }}
|
||||||
projects:
|
projects:
|
||||||
kubezero:
|
kubezero:
|
||||||
namespace: argocd
|
namespace: argocd
|
||||||
|
@ -1,104 +0,0 @@
|
|||||||
{{- define "argocd-values" }}
|
|
||||||
|
|
||||||
argo-cd:
|
|
||||||
{{- with index .Values "argocd" "configs" }}
|
|
||||||
configs:
|
|
||||||
{{- toYaml . | nindent 4 }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
controller:
|
|
||||||
metrics:
|
|
||||||
enabled: {{ .Values.metrics.enabled }}
|
|
||||||
repoServer:
|
|
||||||
metrics:
|
|
||||||
enabled: {{ .Values.metrics.enabled }}
|
|
||||||
server:
|
|
||||||
metrics:
|
|
||||||
enabled: {{ .Values.metrics.enabled }}
|
|
||||||
|
|
||||||
argocd-apps:
|
|
||||||
projects:
|
|
||||||
- name: kubezero
|
|
||||||
namespace: argocd
|
|
||||||
description: KubeZero - ZeroDownTime Kubernetes Platform
|
|
||||||
sourceRepos:
|
|
||||||
- {{ .Values.kubezero.repoURL }}
|
|
||||||
{{- with .Values.kubezero.gitSync.repoURL }}
|
|
||||||
- {{ . }}
|
|
||||||
{{- end }}
|
|
||||||
destinations:
|
|
||||||
- namespace: '*'
|
|
||||||
server: https://kubernetes.default.svc
|
|
||||||
clusterResourceWhitelist:
|
|
||||||
- group: '*'
|
|
||||||
kind: '*'
|
|
||||||
applications:
|
|
||||||
- name: kubezero-git-sync
|
|
||||||
namespace: argocd
|
|
||||||
project: kubezero
|
|
||||||
source:
|
|
||||||
repoURL: {{ .Values.kubezero.gitSync.repoURL }}
|
|
||||||
targetRevision: {{ .Values.kubezero.gitSync.targetRevision }}
|
|
||||||
path: {{ .Values.kubezero.gitSync.path }}
|
|
||||||
|
|
||||||
directory:
|
|
||||||
recurse: true
|
|
||||||
|
|
||||||
destination:
|
|
||||||
server: https://kubernetes.default.svc
|
|
||||||
namespace: argocd
|
|
||||||
|
|
||||||
{{- with .Values.kubezero.syncPolicy }}
|
|
||||||
syncPolicy:
|
|
||||||
{{- toYaml . | nindent 8 }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
argocd-image-updater:
|
|
||||||
enabled: {{ default "false" (index .Values "argocd" "argocd-image-updater" "enabled") }}
|
|
||||||
|
|
||||||
{{- with omit (index .Values "argocd" "argocd-image-updater") "enabled" }}
|
|
||||||
{{- toYaml . | nindent 2 }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- if .Values.global.aws }}
|
|
||||||
extraEnv:
|
|
||||||
- name: AWS_ROLE_ARN
|
|
||||||
value: "arn:aws:iam::{{ .Values.global.aws.accountId }}:role/{{ .Values.global.aws.region }}.{{ .Values.global.clusterName }}.argocd-image-updater"
|
|
||||||
- name: AWS_WEB_IDENTITY_TOKEN_FILE
|
|
||||||
value: "/var/run/secrets/sts.amazonaws.com/serviceaccount/token"
|
|
||||||
- name: AWS_STS_REGIONAL_ENDPOINTS
|
|
||||||
value: "regional"
|
|
||||||
- name: METADATA_TRIES
|
|
||||||
value: "0"
|
|
||||||
- name: AWS_REGION
|
|
||||||
value: {{ .Values.global.aws.region }}
|
|
||||||
volumes:
|
|
||||||
- name: aws-token
|
|
||||||
projected:
|
|
||||||
sources:
|
|
||||||
- serviceAccountToken:
|
|
||||||
path: token
|
|
||||||
expirationSeconds: 86400
|
|
||||||
audience: "sts.amazonaws.com"
|
|
||||||
volumeMounts:
|
|
||||||
- name: aws-token
|
|
||||||
mountPath: "/var/run/secrets/sts.amazonaws.com/serviceaccount/"
|
|
||||||
readOnly: true
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
metrics:
|
|
||||||
enabled: {{ .Values.metrics.enabled }}
|
|
||||||
|
|
||||||
{{- if and ( index .Values "argocd" "istio" "enabled" ) .Values.istio.enabled }}
|
|
||||||
istio:
|
|
||||||
{{- with index .Values "argocd" "istio" }}
|
|
||||||
{{- toYaml . | nindent 2 }}
|
|
||||||
{{- end }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{- define "argocd-argo" }}
|
|
||||||
{{- end }}
|
|
||||||
|
|
||||||
{{ include "kubezero-app.app" . }}
|
|
@ -37,6 +37,12 @@ metallb:
|
|||||||
|
|
||||||
|
|
||||||
{{- define "network-argo" }}
|
{{- define "network-argo" }}
|
||||||
|
# Metallb
|
||||||
|
ignoreDifferences:
|
||||||
|
- group: apiextensions.k8s.io
|
||||||
|
kind: CustomResourceDefinition
|
||||||
|
jsonPointers:
|
||||||
|
- /spec/conversion/webhook/clientConfig/caBundle
|
||||||
{{- end }}
|
{{- end }}
|
||||||
|
|
||||||
{{ include "kubezero-app.app" . }}
|
{{ include "kubezero-app.app" . }}
|
||||||
|
@ -30,18 +30,18 @@ addons:
|
|||||||
network:
|
network:
|
||||||
enabled: true
|
enabled: true
|
||||||
retain: true
|
retain: true
|
||||||
targetRevision: 0.5.0
|
targetRevision: 0.5.1
|
||||||
cilium:
|
cilium:
|
||||||
cluster: {}
|
cluster: {}
|
||||||
|
|
||||||
cert-manager:
|
cert-manager:
|
||||||
enabled: false
|
enabled: false
|
||||||
namespace: cert-manager
|
namespace: cert-manager
|
||||||
targetRevision: 0.9.6
|
targetRevision: 0.9.7
|
||||||
|
|
||||||
storage:
|
storage:
|
||||||
enabled: false
|
enabled: false
|
||||||
targetRevision: 0.8.5
|
targetRevision: 0.8.6
|
||||||
lvm-localpv:
|
lvm-localpv:
|
||||||
enabled: false
|
enabled: false
|
||||||
aws-ebs-csi-driver:
|
aws-ebs-csi-driver:
|
||||||
@ -110,11 +110,13 @@ logging:
|
|||||||
namespace: logging
|
namespace: logging
|
||||||
targetRevision: 0.8.10
|
targetRevision: 0.8.10
|
||||||
|
|
||||||
argocd:
|
argo:
|
||||||
enabled: false
|
enabled: false
|
||||||
namespace: argocd
|
namespace: argocd
|
||||||
targetRevision: 0.13.3
|
targetRevision: 0.2.0
|
||||||
|
argo-cd:
|
||||||
|
enabled: false
|
||||||
|
istio:
|
||||||
|
enabled: false
|
||||||
argocd-image-updater:
|
argocd-image-updater:
|
||||||
enabled: false
|
enabled: false
|
||||||
istio:
|
|
||||||
enabled: false
|
|
||||||
|
@ -4,6 +4,7 @@
|
|||||||
- all KubeZero and support AMIs based on Alpine 3.19.1
|
- all KubeZero and support AMIs based on Alpine 3.19.1
|
||||||
- further reduced boot time, eg. less than 30s for a bastion on EC2
|
- further reduced boot time, eg. less than 30s for a bastion on EC2
|
||||||
- sub-second timestamps for all system logs
|
- sub-second timestamps for all system logs
|
||||||
|
- enabled TransparentHugePages incl. save settings for Golang
|
||||||
|
|
||||||
|
|
||||||
## Fixes
|
## Fixes
|
||||||
|
Loading…
Reference in New Issue
Block a user