cert-rotation: Correct and enhance the rotation script.

Corrected the counter increment and enhanced the script to handle
situation if the certificate is stuck in issuing state.

Change-Id: Ib8a84831a605bb3e5a1fc5b5a909c827ec864797
This commit is contained in:
Gupta, Sangeet (sg774j) 2021-08-24 15:00:13 +00:00 committed by Sangeet Gupta
parent 1062d68eed
commit 222f7b6877
3 changed files with 23 additions and 5 deletions

View File

@ -16,5 +16,5 @@ appVersion: "1.0"
description: Rotate the certificates generated by cert-manager description: Rotate the certificates generated by cert-manager
home: https://cert-manager.io/ home: https://cert-manager.io/
name: cert-rotation name: cert-rotation
version: 0.1.1 version: 0.1.2
... ...

View File

@ -55,17 +55,34 @@ function rotate_and_get_certs_list(){
for cert in ${certRotated[@]} for cert in ${certRotated[@]}
do do
counter=0 counter=0
retried=false
while [ "$(kubectl get certificate -n ${namespace} ${cert} -o json | jq -r '.status.conditions[].status')" != "True" ] while [ "$(kubectl get certificate -n ${namespace} ${cert} -o json | jq -r '.status.conditions[].status')" != "True" ]
do do
# Wait for secret to become ready. Wait for 300 seconds maximum. Sleep for 10 seconds # Wait for secret to become ready. Wait for 300 seconds maximum. Sleep for 10 seconds
if [ ${counter} -ge 30 ] if [ ${counter} -ge 30 ]
then then
# Seems certificate is not in ready state yet, may be there is an issue be renewing the certificate.
# Try one more time before failing it. The name of the secret would be different at this time (when in
# process of issuing)
priSeckeyName=$(kubectl get certificate -n ${namespace} ${cert} -o json | jq -r '.status["nextPrivateKeySecretName"]')
if [ ${retried} = false ] && [ ! -z ${priSeckeyName} ]
then
echo "Deleting interim failed secret ${priSeckeyName} in namespace ${namespace}"
kubectl delete secret -n ${namespace} ${priSeckeyName}
retried=true
counter=0
else
# Tried 2 times to renew the certificate, something is not right. Log error and
# continue to check the status of next certificate. Once the status of all the
# certificates has been checked, the pods need to be restarted so that the successfully
# renewed certificates can be deployed.
echo "ERROR: Rotated certificate ${cert} in ${namespace} is not ready." echo "ERROR: Rotated certificate ${cert} in ${namespace} is not ready."
# Continue so that the certificates that are rotated successfully are deployed.
break break
fi fi
fi
echo "Rotated certificate ${cert} in ${namespace} is not ready yet ... waiting" echo "Rotated certificate ${cert} in ${namespace} is not ready yet ... waiting"
counter+=(${counter+=1}) counter=$((counter+1))
sleep 10 sleep 10
done done

View File

@ -2,4 +2,5 @@
cert-rotation: cert-rotation:
- 0.1.0 Initial Chart - 0.1.0 Initial Chart
- 0.1.1 Return true if grep finds no match - 0.1.1 Return true if grep finds no match
- 0.1.2 Correct and enhance the rotation script
... ...