Kubernetes
[K8S] 쿠버네티스 - 잡(Job) 기능
끄적이는 물고기
2022. 8. 14. 18:10
반응형
잡(Job)
잡에서 하나 이상의 파드를 생성하고 지정된 수의 파드가 성공적으로 종료될 때까지 계속해서 파드의 실행을 재시도한다. 파드가 성공적으로 완료되면, 성공적으로 완료된 잡을 추적한다. 지정된 수의 성공 완료에 도달하면, 작업(즉, 잡)이 완료된다. 잡을 삭제하면 잡이 생성한 파드가 정리된다. 작업을 일시 중지하면 작업이 다시 재개될 때까지 활성 파드가 삭제된다.
간단한 사례는 잡 오브젝트를 하나 생성해서 파드 하나를 안정적으로 실행하고 완료하는 것이다. 첫 번째 파드가 실패 또는 삭제된 경우(예로는 노드 하드웨어의 실패 또는 노드 재부팅) 잡 오브젝트는 새로운 파드를 기동시킨다.
잡을 사용하면 여러 파드를 병렬로 실행할 수도 있다.
잡을 스케줄에 따라 구동하고 싶은 경우(단일 작업이든, 여러 작업의 병렬 수행이든), 크론잡(CronJob)을 참고한다.
- 1회성 배치작업(데이터수집, 분석, 기계학습)
잡(Job) 사용
# job 배포 YAML 파일 생성 (date 기능)
jinsu@jinsu:~$ cat job.yaml
apiVersion: batch/v1
kind: Job
metadata:
name: myfirstjob
spec:
template:
spec:
containers:
- name: print-date
image: busybox
args: ["date"]
restartPolicy: OnFailure
backoffLimit: 2
jinsu@jinsu:~$
# job 배보
jinsu@jinsu:~$ kubectl apply -f job.yaml
job.batch/myfirstjob created
jinsu@jinsu:~$
# job 상태 확인
jinsu@jinsu:~$ kubectl get job
NAME COMPLETIONS DURATION AGE
myfirstjob 1/1 5s 5s
jinsu@jinsu:~$
# job pod 확인
jinsu@jinsu:~$ kubectl get pod
NAME READY STATUS RESTARTS AGE
myfirstjob-bl5w8 0/1 Completed 0 16s
jinsu@jinsu:~$
# job 상세정보 (restartPolicy: OnFailure) job 기능 상태확인
jinsu@jinsu:~$ kubectl get job myfirstjob -oyaml
apiVersion: batch/v1
kind: Job
metadata:
annotations:
kubectl.kubernetes.io/last-applied-configuration: |
{"apiVersion":"batch/v1","kind":"Job","metadata":{"annotations":{},"name":"myfirstjob","namespace":"default"},"spec":{"backoffLimit":2,"template":{"spec":{"containers":[{"args":["date"],"image":"busybox","name":"print-date"}],"restartPolicy":"OnFailure"}}}}
creationTimestamp: "2022-08-14T09:12:55Z"
labels:
controller-uid: 102804d2-35af-451e-8e52-b428b626a35d
job-name: myfirstjob
name: myfirstjob
namespace: default
resourceVersion: "18588"
selfLink: /apis/batch/v1/namespaces/default/jobs/myfirstjob
uid: 102804d2-35af-451e-8e52-b428b626a35d
spec:
backoffLimit: 2
completions: 1
parallelism: 1
selector:
matchLabels:
controller-uid: 102804d2-35af-451e-8e52-b428b626a35d
template:
metadata:
creationTimestamp: null
labels:
controller-uid: 102804d2-35af-451e-8e52-b428b626a35d
job-name: myfirstjob
spec:
containers:
- args:
- date
image: busybox
imagePullPolicy: Always
name: print-date
resources: {}
terminationMessagePath: /dev/termination-log
terminationMessagePolicy: File
dnsPolicy: ClusterFirst
restartPolicy: OnFailure
schedulerName: default-scheduler
securityContext: {}
terminationGracePeriodSeconds: 30
status:
completionTime: "2022-08-14T09:13:00Z"
conditions:
- lastProbeTime: "2022-08-14T09:13:00Z"
lastTransitionTime: "2022-08-14T09:13:00Z"
status: "True"
type: Complete
startTime: "2022-08-14T09:12:55Z"
succeeded: 1
jinsu@jinsu:~$
# job으로 생성한 date 기능 확인
jinsu@jinsu:~$ kubectl logs myfirstjob-bl5w8
Sun Aug 14 09:12:59 UTC 2022
jinsu@jinsu:~$
# job 생성할때 date2로 생성
jinsu@jinsu:~$ cat job.yaml
apiVersion: batch/v1
kind: Job
metadata:
name: myfirstjob
spec:
template:
spec:
containers:
- name: print-date
image: busybox
args: ["date2"]
restartPolicy: OnFailure
backoffLimit: 2
jinsu@jinsu:~$
# job 생성 및 확인
jinsu@jinsu:~$ kubectl apply -f job.yaml
job.batch/myfirstjob created
jinsu@jinsu:~$
jinsu@jinsu:~$ kubectl get job
NAME COMPLETIONS DURATION AGE
myfirstjob 0/1 3s 3s
jinsu@jinsu:~$
# pod에 문제가 생겨 RESTARTS 카운트가 올라가 2회 발생시 Pod가 자동 삭제 확인
jinsu@jinsu:~$ kubectl get pod
NAME READY STATUS RESTARTS AGE
myfirstjob-bl2lb 0/1 RunContainerError 0 8s
jinsu@jinsu:~$ kubectl get pod
NAME READY STATUS RESTARTS AGE
myfirstjob-bl2lb 0/1 Terminating 2 36s
jinsu@jinsu:~$
잡(Job) 삭제
# 현재 job 상태
jinsu@jinsu:~$ kubectl get job
NAME COMPLETIONS DURATION AGE
myfirstjob 0/1 4m40s 4m40s
# job 삭제
jinsu@jinsu:~$ kubectl delete job myfirstjob
job.batch "myfirstjob" deleted
jinsu@jinsu:~$
jinsu@jinsu:~$ kubectl get job
No resources found in default namespace.
jinsu@jinsu:~$
참고자료
https://kubernetes.io/ko/docs/concepts/workloads/controllers/job/
반응형