test of deployment use kubectl
Some checks failed
Build and Push Docker Image / build-and-push (push) Failing after 10s
Some checks failed
Build and Push Docker Image / build-and-push (push) Failing after 10s
This commit is contained in:
@@ -76,59 +76,28 @@ jobs:
|
|||||||
docker push "${IMAGE_REPO}:latest"
|
docker push "${IMAGE_REPO}:latest"
|
||||||
docker push "${IMAGE_REPO}:${SHORT_SHA}"
|
docker push "${IMAGE_REPO}:${SHORT_SHA}"
|
||||||
|
|
||||||
- name: Install helm and kubectl
|
- name: Setup kubectl
|
||||||
run: |
|
run: |
|
||||||
ARCH="$(uname -m)"
|
|
||||||
if [ "${ARCH}" = "x86_64" ]; then
|
|
||||||
ARCH="amd64"
|
|
||||||
elif [ "${ARCH}" = "aarch64" ]; then
|
|
||||||
ARCH="arm64"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! command -v helm >/dev/null 2>&1; then
|
|
||||||
apk add --no-cache curl tar gzip ca-certificates
|
|
||||||
HELM_VERSION="v3.16.4"
|
|
||||||
curl -fsSL "https://get.helm.sh/helm-${HELM_VERSION}-linux-${ARCH}.tar.gz" -o /tmp/helm.tgz
|
|
||||||
tar -xzf /tmp/helm.tgz -C /tmp
|
|
||||||
mv "/tmp/linux-${ARCH}/helm" /usr/local/bin/helm
|
|
||||||
chmod +x /usr/local/bin/helm
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! command -v kubectl >/dev/null 2>&1; then
|
|
||||||
KUBECTL_VERSION="v1.31.2"
|
|
||||||
curl -fsSL "https://dl.k8s.io/release/${KUBECTL_VERSION}/bin/linux/${ARCH}/kubectl" -o /usr/local/bin/kubectl
|
|
||||||
chmod +x /usr/local/bin/kubectl
|
|
||||||
fi
|
|
||||||
|
|
||||||
helm version
|
|
||||||
kubectl version --client
|
|
||||||
|
|
||||||
- name: Deploy to Dagster with Helm
|
|
||||||
run: |
|
|
||||||
if [ -z "${{ secrets.KUBE_CONFIG_B64 }}" ]; then
|
|
||||||
echo "Missing KUBE_CONFIG_B64 secret"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
COMMIT_SHA="${GITHUB_SHA:-$GITEA_SHA}"
|
|
||||||
SHORT_SHA="$(echo "${COMMIT_SHA}" | cut -c1-12)"
|
|
||||||
|
|
||||||
mkdir -p "${HOME}/.kube"
|
mkdir -p "${HOME}/.kube"
|
||||||
echo "${{ secrets.KUBE_CONFIG_B64 }}" | base64 -d > "${HOME}/.kube/config"
|
echo "${{ secrets.KUBE_CONFIG_B64 }}" | base64 -d > "${HOME}/.kube/config"
|
||||||
export KUBECONFIG="${HOME}/.kube/config"
|
chmod 600 "${HOME}/.kube/config"
|
||||||
|
|
||||||
helm upgrade --install "${HELM_RELEASE}" dagster \
|
- name: Update Dagster user deployment image
|
||||||
--repo "https://code.europa.eu/api/v4/projects/1304/packages/helm/stable" \
|
run: |
|
||||||
--version "${DAGSTER_CHART_VERSION}" \
|
COMMIT_SHA="${GITHUB_SHA:-$GITEA_SHA}"
|
||||||
--namespace "${K8S_NAMESPACE}" \
|
SHORT_SHA="$(echo "${COMMIT_SHA}" | cut -c1-12)"
|
||||||
--reuse-values \
|
|
||||||
--set-string "dagster.dagster-user-deployments.deployments[0].image.repository=${IMAGE_REPO}" \
|
# Patch the dagster-user-deployments to update the image tag
|
||||||
--set-string "dagster.dagster-user-deployments.deployments[0].image.tag=${SHORT_SHA}"
|
kubectl patch statefulset dagster-user-deployments \
|
||||||
|
-n "${K8S_NAMESPACE}" \
|
||||||
DEPLOYMENT_NAME="$(kubectl -n "${K8S_NAMESPACE}" get deployment -o jsonpath='{range .items[*]}{.metadata.name}{"\n"}{end}' | grep 'template-code-location' | head -n 1)"
|
--type='json' \
|
||||||
if [ -n "${DEPLOYMENT_NAME}" ]; then
|
-p="[{'op': 'replace', 'path': '/spec/template/spec/containers/0/image', 'value':'${IMAGE_REPO}:${SHORT_SHA}'}]"
|
||||||
kubectl -n "${K8S_NAMESPACE}" rollout restart "deployment/${DEPLOYMENT_NAME}"
|
|
||||||
kubectl -n "${K8S_NAMESPACE}" rollout status "deployment/${DEPLOYMENT_NAME}" --timeout=300s
|
# Trigger rollout restart to pick up new image
|
||||||
else
|
kubectl rollout restart statefulset/dagster-user-deployments \
|
||||||
echo "No deployment name matched template-code-location; Helm upgrade completed without explicit rollout restart."
|
-n "${K8S_NAMESPACE}"
|
||||||
fi
|
|
||||||
|
# Wait for rollout to complete
|
||||||
|
kubectl rollout status statefulset/dagster-user-deployments \
|
||||||
|
-n "${K8S_NAMESPACE}" \
|
||||||
|
--timeout=5m
|
||||||
|
|||||||
Reference in New Issue
Block a user