클라우드/쿠버네티스

cronjob의 타임존 설정

ybchoi 2024. 1. 4. 20:08

쿠버네티스 타임존은 기본적으로 UTC로 동작하며 이를 변경할수 없음

파드 내부의 타임존은 timezone파일을 마운트 하여 맞출수 있지만 크론탭의 경우 불가능함

일반적인 사용에는 -9해서 만들면 되니까 큰 문제가 없는데

 

만약 매달 1일 05시에 도는 잡이라면 문제가 발생

 

 
 
30 8 1 * * /usr/bin/bash test3
0 5 1 * * /usr/bin/bash  test1
0 6 1 * * /usr/bin/bash  test

 

이게 왜 문제냐면 위 시간은 UTC라 KST로 조정하면 1일이 아니고 매달 말일임

 

매달 말일의 경우 크론탭으로는 설정이 불가능(28일,30일,31일 등 여러가지 조건이 있으므로)

 

해서 일반적으로 크론탭에서는 아래와 같은 방법을 쓰는데

 

 
30 23 28-31 * * [ $(date +\%d -d tomorrow) = 02 ] && /usr/bin/bash test
 

위와같이 설정하면 매달 28~31일날(UTC기준) 실행되는데 다음날이 2일(KST기준)인 경우에만 실행 한다(원래는 1일이나 파드내부는 KST 크론잡 타임은 UTC이므로 위와같이 설정해야함) 외 내부 타임존이 다르기때문에 계산하는것도 두번해야하고 관리도 번거로움

이렇게 적용을 하려다가 크론잡 doc을 보니 1.25부터 크론잡 타임존이 베타로 승격됨

 

타임 존

크론잡에 타임 존이 명시되어 있지 않으면, kube-controller-manager는 로컬 타임 존을 기준으로 스케줄을 해석한다.

기능 상태: Kubernetes v1.25 [beta]

CronJobTimeZone 기능 게이트를 활성화하면, 크론잡에 대해 타임 존을 명시할 수 있다(기능 게이트를 활성화하지 않거나, 타임 존에 대한 실험적 지원을 제공하지 않는 쿠버네티스 버전을 사용 중인 경우, 클러스터의 모든 크론잡은 타임 존이 명시되지 않은 것으로 동작한다).

이 기능을 활성화하면, spec.timeZone을 유효한 타임 존으로 지정할 수 있다. 예를 들어, spec.timeZone: "Etc/UTC"와 같이 설정하면 쿠버네티스는 협정 세계시를 기준으로 스케줄을 해석한다.

Go 표준 라이브러리의 타임 존 데이터베이스가 바이너리로 인클루드되며, 시스템에서 외부 데이터베이스를 사용할 수 없을 때 폴백(fallback)으로 사용된다

 

아래와 같이 설정

 

 
spec:
  schedule: "30 8 1 * *"
  successfulJobsHistoryLimit: 1
  timeZone: 'Asia/Seoul'

굳이 -9 계산안해도 편하게 타임존 설정가능

 

쿠버네티스 기본 기조자체가 UTC를 써라 tz관련된 그 어떤 피쳐도 없다 였는데

 

크론잡의 경우 위같은 문제가 워낙 많아 최근에 생긴듯

 

위와같이 모든 잡에 적용 했으며 매일 6~9시 사이 도는 잡이 있으니 익일 KST기준으로 잘 도는지 체크

 

기존잡에 timezone만 추가해서 그런지 정상적으로 적용이 되지 않았음(09시 도는 잡이 18시에 돔)

전체 잡을 삭제하고 다시 적용했고

 
    State:          Terminated
      Reason:       Completed
      Exit Code:    0
      Started:      Wed, 26 Jul 2023 09:05:01 +0900
      Finished:     Wed, 26 Jul 2023 09:05:01 +0900

 

정상적으로 KST 09시에 돔