次のKubernetesジョブ構成があります。
---
apiVersion: batch/v1
kind: Job
metadata:
name: dbload
creationTimestamp:
spec:
template:
metadata:
name: dbload
spec:
containers:
- name: dbload
image: sdvl3prox001:7001/pbench/tdload
command: ["/opt/pbench/loadTpcdsData.sh", "qas0063", "dbc", "dbc", "1"]
restartPolicy: Never
imagePullSecrets:
- name: pbenchregkey
status: {}
kubectl create -f dbload-deployment.yml --record
ジョブを実行してポッドが作成されると、Dockerコンテナーが完了するまで実行され、次のステータスが表示されます。
$ kubectl get job dbload
NAME DESIRED SUCCESSFUL AGE
dbload 1 1 1h
$ kubectl get pods -a
NAME READY STATUS RESTARTS AGE
dbload-0mk0d 0/1 Completed 0 1h
この仕事は一度きりであり、再実行できるようにする必要があります。kubectl create
コマンドで再実行しようとすると、このエラーが発生します
$ kubectl create -f dbload-deployment.yml --record
Error from server: error when creating "dbload-deployment.yml": jobs.batch "dbload" already exists
もちろんkubectl delete job dbload
、実行してから実行できますkubectl create
が、既に存在するジョブを何らかの形で再起動できるかどうか疑問に思っていますか?
kubectl replace
再作成するエラーが発生する前にジョブを削除します。