Skip to content

Trigger ontop-materialize job in k8s #44

Trigger ontop-materialize job in k8s

Trigger ontop-materialize job in k8s #44

Workflow file for this run

# This workflow will run the ontop-materialize job in the identifiers kubernetes cluster
# which generates triples for the Identifiers registry ontologies
name: 'Trigger ontop-materialize job in k8s'
on:
schedule:
- cron: '0 7 * * *' # Run at 7:00 AM every day
push:
branches:
- main
jobs:
setup-build-publish-deploy:
name: 'Update triples and server'
runs-on: 'ubuntu-latest'
environment: 'production'
permissions:
contents: 'read'
id-token: 'write'
steps:
- name: 'Checkout'
uses: 'actions/checkout@692973e3d937129bcbf40652eb9f2f61becf3332' # actions/checkout@v4
# Configure Workload Identity Federation and generate an access token.
#
# See https://github.com/google-github-actions/auth for more options,
# including authenticating via a JSON credentials file.
- id: 'auth'
name: 'Authenticate to Google Cloud'
uses: 'google-github-actions/auth@f112390a2df9932162083945e46d439060d66ec2' # google-github-actions/auth@v2
with:
project_id: '${{ secrets.GCP_PROJECT_ID }}'
workload_identity_provider: '${{ secrets.GCP_WORKLOAD_IDENTITY_PROVIDER }}'
# Get the GKE credentials so we can deploy to the cluster
- name: 'Set up GKE credentials'
uses: 'google-github-actions/get-gke-credentials@6051de21ad50fbb1767bc93c11357a49082ad116' # google-github-actions/get-gke-credentials@v2
with:
cluster_name: '${{ secrets.GKE_CLUSTER }}'
location: '${{ secrets.GCP_CLUSTER_LOCATION }}'
# Deploy the Docker image to the GKE cluster
- name: 'Update materialized triples job'
run: >-
kubectl -n hq delete -f ontop-k8s-job.yaml &&
kubectl -n hq apply -f ontop-k8s-job.yaml &&
kubectl -n hq wait --for=condition=complete --timeout=60s -f ontop-k8s-job.yaml
- name: 'Restart SPARQL server'
run: >-
kubectl -n satellite rollout restart deployment/sparql &&
kubectl -n satellite rollout status deployment/sparql --timeout=60s