Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

remove prometheus CR before LMA appgroup removal #73

Merged
merged 2 commits into from
Mar 2, 2022
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
10 changes: 10 additions & 0 deletions templates/argo-additional-rbac.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -65,3 +65,13 @@ rules:
- delete
- list
- patch
- apiGroups:
- monitoring.coreos.com
resources:
- prometheuses
- alertmanagers
verbs:
- create
- get
- delete
- list
18 changes: 10 additions & 8 deletions templates/argo-cd/delete-apps-by-label-wftpl.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -4,11 +4,13 @@ metadata:
name: delete-apps
namespace: argo
spec:
arguments:
parameters:
# Filter to filter argocd apps (E.g., "app=lma")
- name: filter
value: ""
templates:
- name: DeleteAppsByLabel
inputs:
parameters:
- name: filter
activeDeadlineSeconds: 900
container:
name: 'delete-apps'
Expand All @@ -33,10 +35,10 @@ spec:

deleted=False

# Delete normal apps including CRs
# Delete normal apps except operators and CRs
app_list=$(./argocd app list -l $FILTER --output name | grep -v operator)
if [[ $? -eq 0 && -n $app_list ]]; then
echo "[1st phase] Deleting apps: $app_list"
echo -e "[1st phase] Deleting apps:\n$app_list"
echo "$app_list" | xargs ./argocd app delete --cascade -y

until [ $(./argocd app list -l $FILTER --output name | grep -v operator | wc -l) == 0 ]
Expand All @@ -51,10 +53,10 @@ spec:
echo "No apps found except operators. Skipping 1st phase.."
fi

# Delete operators
# Delete operators and CRs
app_list=$(./argocd app list -l $FILTER --output name)
if [[ $? -eq 0 && -n $app_list ]]; then
echo "[2nd phase] Deleting operators: $app_list"
echo -e "[2nd phase] Deleting operators:\n$app_list"
echo "$app_list" | xargs ./argocd app delete --cascade -y

until [ $(./argocd app list -l $FILTER --output name | wc -l) == 0 ]
Expand All @@ -78,4 +80,4 @@ spec:
name: "decapod-argocd-config"
env:
- name: FILTER
value: "{{inputs.parameters.filter}}"
value: "{{workflow.parameters.filter}}"
12 changes: 6 additions & 6 deletions templates/decapod-apps/lma-uniformed-wftpl.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -22,20 +22,19 @@ spec:
value: ""
templates:
- name: prepare
inputs: {}
outputs: {}
metadata: {}
steps:
- - name: configuration
template: configuration
arguments: {}
- - name: deploy
template: deploy
arguments: {}

#######################
# Template Definition #
#######################

- name: configuration
inputs: {}
outputs: {}
metadata: {}
container:
name: config
image: 'k8s.gcr.io/hyperkube:v1.18.8'
Expand All @@ -52,6 +51,7 @@ spec:
resources: {}
imagePullPolicy: IfNotPresent
activeDeadlineSeconds: 120

- name: deploy
dag:
tasks:
Expand Down
99 changes: 90 additions & 9 deletions templates/decapod-apps/remove-lma-uniformed-wftpl.yaml
Original file line number Diff line number Diff line change
@@ -1,4 +1,3 @@
## Example workflow that calls delete-project template ##
apiVersion: argoproj.io/v1alpha1
kind: WorkflowTemplate
metadata:
Expand All @@ -8,29 +7,101 @@ spec:
entrypoint: process
arguments:
parameters:
# Filter to filter argocd apps (E.g., "app=lma")
# 'cluster_id' is used for multi-cluster case
# TODO: better to rename this to 'site_name' later
- name: cluster_id
value: ""
- name: app_prefix
value: ""
# Filter to filter argocd apps
- name: filter
value: "app=lma"
templates:
- name: process
steps:
- - name: disableAutoSyncOfPrometheus
template: disableAutoSync

# Delete prometheus CR first so that it doesn't hang
# due to earlier service-account deletion #
- - name: removePrometheusCR
template: removePrometheusCR
arguments:
parameters:
- name: namespace
value: "lma"

# Remove argo CD apps
- - name: removeLMA
templateRef:
name: delete-apps
template: DeleteAppsByLabel
arguments:
parameters:
- name: filter
value: "{{ workflow.parameters.filter }}"

# LMA appGroup specific task #
# Cleanup secrets and PVCs
- - name: cleanupLeftoverResources
template: removeLeftoverResources
arguments:
parameters:
- name: namespace
value: "lma"

#######################
# Template Definition #
#######################

- name: disableAutoSync
container:
name: disable-auto-sync
image: docker.io/sktcloud/argocd-cli:v2.2.5
command:
- /bin/bash
- '-c'
- |
PROM_APP_NAME="prometheus"
if [[ -n "{{workflow.parameters.app_prefix}}" ]]; then
PROM_APP_NAME="{{workflow.parameters.app_prefix}}-prometheus"
fi
echo "[temp] ARGO_SERVER: $ARGO_SERVER"

# Login to Argo CD server
./argocd login $ARGO_SERVER --plaintext --insecure --username $ARGO_USERNAME \
--password $ARGO_PASSWORD

echo "Disabling auto-sync of [$PROM_APP_NAME]' app.."

# Disable auto-sync
./argocd app set $PROM_APP_NAME --sync-policy none
envFrom:
- secretRef:
name: "decapod-argocd-config"

- name: removePrometheusCR
inputs:
parameters:
- name: namespace
container:
name: remove-prometheus-cr
image: k8s.gcr.io/hyperkube:v1.18.6
command:
- /bin/bash
- '-c'
- |
echo "Deleting prometheus CRs..."

kube_params=""

if [[ -n "{{workflow.parameters.cluster_id}}" ]]; then
kube_secret=$(kubectl get secret -n argo {{workflow.parameters.cluster_id}}-kubeconfig -o jsonpath="{.data.value}" | base64 -d)
robertchoi80 marked this conversation as resolved.
Show resolved Hide resolved
echo -e "kube_secret:\n$kube_secret" | head -n 5
cat <<< "$kube_secret" > /etc/kubeconfig

kube_params+="--kubeconfig=/etc/kubeconfig"
fi

kubectl $kube_params delete prometheus --all -n {{inputs.parameters.namespace}}
kubectl $kube_params delete alertmanager --all -n {{inputs.parameters.namespace}}


- name: removeLeftoverResources
inputs:
parameters:
Expand All @@ -42,5 +113,15 @@ spec:
- /bin/bash
- '-c'
- |
kubectl delete secret etcd-client-cert prometheus-operator-admission -n {{inputs.parameters.namespace}} || true
kubectl delete pvc --all -n {{inputs.parameters.namespace}}
echo "Deleting secrets and PVCs..."

kube_params=""
if [[ -n "{{workflow.parameters.cluster_id}}" ]]; then
kube_secret=$(kubectl get secret -n argo {{workflow.parameters.cluster_id}}-kubeconfig -o jsonpath="{.data.value}" | base64 -d)
cat <<< "$kube_secret" > /etc/kubeconfig
robertchoi80 marked this conversation as resolved.
Show resolved Hide resolved

kube_params+="--kubeconfig=/etc/kubeconfig"
fi

kubectl $kube_params delete secret etcd-client-cert prometheus-operator-admission -n {{inputs.parameters.namespace}} || true
kubectl $kube_params delete pvc --all -n {{inputs.parameters.namespace}}