Use shared CI/CD workflow from alo-cluster
All checks were successful
Deploy / deploy (push) Successful in 2m40s
All checks were successful
Deploy / deploy (push) Successful in 2m40s
Simplify workflow to use reusable workflow: uses: ppetru/alo-cluster/.gitea/workflows/deploy-nomad.yaml@master All build/push/deploy logic is now centralized in alo-cluster. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -1,71 +1,13 @@
|
|||||||
name: Build and Deploy
|
name: Deploy
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: [master]
|
branches: [master]
|
||||||
workflow_dispatch:
|
workflow_dispatch:
|
||||||
|
|
||||||
env:
|
|
||||||
REGISTRY: gitea.v.paler.net
|
|
||||||
IMAGE: ppetru/animaltrack
|
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-and-deploy:
|
deploy:
|
||||||
runs-on: nix
|
uses: ppetru/alo-cluster/.gitea/workflows/deploy-nomad.yaml@master
|
||||||
steps:
|
with:
|
||||||
- uses: actions/checkout@v4
|
service_name: animaltrack
|
||||||
|
secrets: inherit
|
||||||
- name: Build Docker image
|
|
||||||
run: |
|
|
||||||
nix build .#dockerImage --out-link result
|
|
||||||
|
|
||||||
- name: Push to registry
|
|
||||||
run: |
|
|
||||||
skopeo copy \
|
|
||||||
--dest-creds "${{ secrets.REGISTRY_USERNAME }}:${{ secrets.REGISTRY_PASSWORD }}" \
|
|
||||||
--insecure-policy \
|
|
||||||
docker-archive:result \
|
|
||||||
docker://${{ env.REGISTRY }}/${{ env.IMAGE }}:latest
|
|
||||||
|
|
||||||
- name: Deploy to Nomad
|
|
||||||
env:
|
|
||||||
NOMAD_ADDR: ${{ secrets.NOMAD_ADDR }}
|
|
||||||
run: |
|
|
||||||
# Fetch current job, update meta.uuid to force deployment, resubmit
|
|
||||||
echo "Fetching current job spec..."
|
|
||||||
JOB=$(curl -sS "$NOMAD_ADDR/v1/job/animaltrack")
|
|
||||||
|
|
||||||
# Update meta.uuid to force a new deployment
|
|
||||||
NEW_UUID=$(cat /proc/sys/kernel/random/uuid)
|
|
||||||
echo "Setting new UUID: $NEW_UUID"
|
|
||||||
UPDATED_JOB=$(echo "$JOB" | jq --arg uuid "$NEW_UUID" '.Meta.uuid = $uuid')
|
|
||||||
|
|
||||||
# Submit the updated job
|
|
||||||
echo "Submitting job..."
|
|
||||||
RESULT=$(echo "{\"Job\": $UPDATED_JOB}" | curl -sS -X POST "$NOMAD_ADDR/v1/jobs" \
|
|
||||||
-H "Content-Type: application/json" -d @-)
|
|
||||||
echo "Submit result: $RESULT"
|
|
||||||
|
|
||||||
# Wait for deployment to be created
|
|
||||||
sleep 3
|
|
||||||
|
|
||||||
echo "Fetching deployments..."
|
|
||||||
DEPLOY_ID=$(curl -sS "$NOMAD_ADDR/v1/job/animaltrack/deployments" | jq -r '.[0].ID')
|
|
||||||
echo "Deployment ID: $DEPLOY_ID"
|
|
||||||
|
|
||||||
if [ "$DEPLOY_ID" = "null" ] || [ -z "$DEPLOY_ID" ]; then
|
|
||||||
echo "No deployment created"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
for i in $(seq 1 30); do
|
|
||||||
STATUS=$(curl -sS "$NOMAD_ADDR/v1/deployment/$DEPLOY_ID" | jq -r '.Status')
|
|
||||||
echo "Deployment status: $STATUS"
|
|
||||||
case $STATUS in
|
|
||||||
successful) exit 0 ;;
|
|
||||||
failed|cancelled) exit 1 ;;
|
|
||||||
esac
|
|
||||||
sleep 10
|
|
||||||
done
|
|
||||||
echo "Timeout waiting for deployment"
|
|
||||||
exit 1
|
|
||||||
|
|||||||
Reference in New Issue
Block a user