--- apiVersion: batch/v1 items: - apiVersion: batch/v1 kind: CronJob metadata: annotations: imageregistry.operator.openshift.io/checksum: sha256:bba822428bee8e742be79fbbc0ae746b2394f5710c1a71477e064b9249fc4478 creationTimestamp: "2026-03-19T09:21:35Z" generation: 1 managedFields: - apiVersion: batch/v1 fieldsType: FieldsV1 fieldsV1: f:metadata: f:annotations: .: {} f:imageregistry.operator.openshift.io/checksum: {} f:spec: f:concurrencyPolicy: {} f:failedJobsHistoryLimit: {} f:jobTemplate: f:metadata: f:annotations: .: {} f:openshift.io/required-scc: {} f:labels: .: {} f:created-by: {} f:spec: f:backoffLimit: {} f:template: f:spec: f:affinity: {} f:containers: k:{"name":"image-pruner"}: .: {} f:args: {} f:command: {} f:image: {} f:imagePullPolicy: {} f:name: {} f:resources: .: {} f:requests: .: {} f:cpu: {} f:memory: {} f:terminationMessagePath: {} f:terminationMessagePolicy: {} f:volumeMounts: .: {} k:{"mountPath":"/var/run/configmaps/serviceca"}: .: {} f:mountPath: {} f:name: {} f:readOnly: {} f:dnsPolicy: {} f:priorityClassName: {} f:restartPolicy: {} f:schedulerName: {} f:securityContext: {} f:serviceAccount: {} f:serviceAccountName: {} f:terminationGracePeriodSeconds: {} f:volumes: .: {} k:{"name":"serviceca"}: .: {} f:configMap: .: {} f:defaultMode: {} f:name: {} f:name: {} f:schedule: {} f:startingDeadlineSeconds: {} f:successfulJobsHistoryLimit: {} f:suspend: {} manager: cluster-image-registry-operator operation: Update time: "2026-03-19T09:21:35Z" name: image-pruner namespace: openshift-image-registry resourceVersion: "9257" uid: 64433d1e-3040-4b60-aa8b-b33a39f57d94 spec: concurrencyPolicy: Forbid failedJobsHistoryLimit: 3 jobTemplate: metadata: annotations: openshift.io/required-scc: restricted-v2 creationTimestamp: null labels: created-by: image-pruner spec: backoffLimit: 0 template: metadata: creationTimestamp: null spec: affinity: {} containers: - args: - -c - | set -eu "$@" && exit for i in 1 2 3 4 5; do echo "attempt #$i has failed (exit code $?), going to make another attempt..." >&2 sleep $(($i * 30)) "$@" && break # this is the last command of the script, so its last failure will be exit code of the script done - arg0 - oc - adm - prune - images - --confirm=true - --certificate-authority=/var/run/configmaps/serviceca/service-ca.crt - --keep-tag-revisions=3 - --keep-younger-than=60m - --ignore-invalid-refs=true - --loglevel=1 - --prune-registry=false command: - /bin/sh image: quay.io/openshift-release-dev/ocp-v4.0-art-dev@sha256:c6a4383333a1fd6d05c3f60ec793913f7937ee3d77f002d85e6c61e20507bf55 imagePullPolicy: IfNotPresent name: image-pruner resources: requests: cpu: 100m memory: 256Mi terminationMessagePath: /dev/termination-log terminationMessagePolicy: FallbackToLogsOnError volumeMounts: - mountPath: /var/run/configmaps/serviceca name: serviceca readOnly: true dnsPolicy: ClusterFirst priorityClassName: system-cluster-critical restartPolicy: Never schedulerName: default-scheduler securityContext: {} serviceAccount: pruner serviceAccountName: pruner terminationGracePeriodSeconds: 30 volumes: - configMap: defaultMode: 420 name: serviceca name: serviceca schedule: 0 0 * * * startingDeadlineSeconds: 3600 successfulJobsHistoryLimit: 3 suspend: false status: {} kind: CronJobList metadata: resourceVersion: "49258"