Kubernetes - how to run job only once Kubernetes - how to run job only once kubernetes kubernetes

Kubernetes - how to run job only once


By now this is possible by setting backoffLimit: 0 which tells the controller to do 0 retries. default is 6


If you want a one-try command runner, you probably should create bare pod, because the job will try to execute the command until it's successful or the active deadline is met.

Just create the pod from your template:

apiVersion: v1kind: Podmetadata:  name: pispec:  containers:  - name: pi    image: perl    command: ["exit", "1"]  restartPolicy: Never


Sadly there is currently no way to prevent the job controller to just respawn new pods when they fail, but the kubernetes community is working on a solution, see:

"Backoff policy and failed pod limit" https://github.com/kubernetes/community/pull/583