본문으로 건너뛰기

롤백

배포 후 문제가 발생했나요? 롤백을 사용하면 빠르게 직전 버전으로 복원할 수 있습니다. 새 버전에서 버그가 발견되었거나 성능 문제가 있을 때, 몇 번의 클릭만으로 안정된 이전 버전으로 돌아갈 수 있습니다.

런타임에 따라 롤백 방식이 다릅니다
  • Kubernetes: 운영 모달의 배포 관리 탭에 즉시 롤백 버튼이 있습니다(kubectl rollout undo).
  • Docker · Podman: 별도의 롤백 전용 UI가 없습니다. Deploy 단계에서 이전 이미지 태그를 선택해 재배포하는 방식으로 롤백합니다.
롤백은 언제 필요한가요?
  • 새 버전 배포 후 예상치 못한 오류가 발생했을 때
  • 성능 저하나 메모리 누수가 발견되었을 때
  • 외부 서비스와의 호환성 문제가 발생했을 때
  • 사용자로부터 심각한 버그 리포트가 들어왔을 때

배포 관리 탭

롤백 개요

런타임별로 롤백 방식이 다릅니다.

  • Kubernetes: 운영 모달의 배포 관리 탭에서 즉시 롤백 버튼으로 직전 리비전으로 되돌립니다. 내부적으로 kubectl rollout undo가 실행됩니다.
  • Docker: 별도의 롤백 전용 UI는 없습니다. Deploy 단계에서 이전 이미지 태그를 선택해 재배포하는 방식으로 롤백합니다.
현재 구현 범위

KIOPS UI에서는 직전 리비전(N-1) 으로만 자동 롤백할 수 있습니다. 더 이전 리비전으로 되돌리려면 운영 모달의 명령 실행 탭에서 kubectl rollout undo --to-revision=N 명령을 직접 실행해야 합니다.


Kubernetes 롤백

Step 1: 배포 이력 확인

  1. [서비스 관리] 페이지에서 서비스의 운영 카드를 클릭합니다.
  2. 운영 모달에서 배포 관리 탭을 선택합니다.
  3. 히스토리 조회 버튼을 클릭하면 kubectl rollout history 명령의 출력이 그대로 TextArea에 표시됩니다.

롤아웃 이력 출력 예시

deployment.apps/my-app
REVISION CHANGE-CAUSE
3 kubectl set image deployment/my-app api=registry/api:v1.0.2
4 kubectl set image deployment/my-app api=registry/api:v1.0.3
5 kubectl set image deployment/my-app api=registry/api:v1.0.4
  • 정형화된 테이블이 아니라 kubectl 명령의 표준 출력이 그대로 표시됩니다.
  • 가장 위 또는 가장 아래의 REVISION이 현재 배포된 버전입니다(클러스터 상황에 따라 다름).
  • CHANGE-CAUSE 컬럼에는 배포 시 기록된 명령 또는 어노테이션이 표시됩니다.

Step 2: 즉시 롤백 실행

  1. 히스토리 출력을 보고 직전 리비전으로 되돌릴지 결정합니다.
  2. 즉시 롤백 버튼을 클릭합니다.
  3. 확인 대화상자에서 진행을 승인하면 백엔드가 kubectl rollout undo deployment/<name> -n <namespace> 명령을 실행합니다.
리비전 선택 UI는 없습니다

KIOPS UI에서는 특정 리비전을 골라서 롤백할 수 없습니다. 즉시 롤백 버튼은 항상 --to-revision 인자 없이 호출되어 직전 리비전(N-1) 으로만 되돌립니다.

Step 3: 롤백 결과 확인

롤백이 완료되면 운영 모달의 파드 목록 탭에서 새 ReplicaSet이 정상적으로 기동되었는지 확인합니다.

  • 모든 Pod 상태가 Running 인지
  • 서비스 응답이 정상인지 (Health Check 통과)
  • 로그에 오류가 없는지
  • 주요 기능이 정상 동작하는지

Docker · Podman 롤백

Docker·Podman 환경에는 별도의 롤백 전용 UI가 없습니다. 이전에 성공한 이미지 태그를 선택해 다시 배포하면 롤백 효과를 얻을 수 있습니다.

Step 1: 이전 이미지 태그 확인

  1. [서비스 관리] 페이지에서 서비스를 선택합니다.
  2. 빌드 이력 또는 컨테이너 레지스트리에서 이전에 정상 동작했던 이미지 태그를 확인합니다.
이미지 태그 찾기

태그 형식이 ${BRANCH}-${SHORT_SHA}라면 이전 커밋의 해시로 찾을 수 있습니다.

Step 2: 이전 이미지 재배포

  1. 파이프라인의 Deploy 단계를 클릭합니다.
  2. DockerDeployModal에서 이미지 버전을 이전 버전으로 변경합니다.
  3. 배포 전 자동 백업 옵션이 켜져 있는지 확인합니다. 켜져 있으면 재배포 직전 상태가 백업되어, 재배포 실패 시 직전 상태로 복원할 수 있습니다.
  4. 배포 버튼을 클릭합니다.

Step 3: 컨테이너 상태 확인

운영 모달의 컨테이너 목록 탭에서 새 컨테이너가 Running 상태인지, 로그에 오류가 없는지 확인합니다.


더 이전 리비전으로 롤백 (긴급/수동)

KIOPS UI의 즉시 롤백 버튼으로는 직전 리비전으로만 되돌릴 수 있습니다. 두 단계 이상 이전의 리비전으로 되돌리려면 다음과 같이 명령을 직접 실행하세요.

운영 모달 - 명령 실행 탭에서 실행

  1. 운영 모달의 명령 실행 탭으로 이동합니다.
  2. 다음 명령으로 리비전 목록을 확인합니다.
kubectl rollout history deployment/<deployment-name> -n <namespace>
  1. 원하는 리비전 번호를 골라 롤백합니다.
kubectl rollout undo deployment/<deployment-name> --to-revision=<revision-number> -n <namespace>
수동 롤백 후 상태 확인

명령 실행 탭에서 직접 롤백한 경우, KIOPS의 배포 이력 표시와 실제 클러스터 상태가 일시적으로 불일치할 수 있습니다. 운영 모달의 파드 목록 탭에서 실제 Pod 상태를 확인하고, 필요하면 히스토리 조회 버튼으로 최신 이력을 다시 가져오세요.


롤백 시 주의사항

데이터베이스 마이그레이션

롤백 전 반드시 확인하세요.

  • 스키마 변경: 새 버전에서 테이블/컬럼이 추가/변경되었는지 확인합니다.
  • 데이터 호환성: 새 형식으로 저장된 데이터가 이전 버전과 호환되는지 확인합니다.
  • 마이그레이션 롤백: DB 마이그레이션도 함께 롤백해야 하는지 검토합니다.
파괴적 마이그레이션 주의

컬럼 삭제나 타입 변경 같은 파괴적 마이그레이션이 적용되었다면 단순 롤백이 어려울 수 있습니다. DB 백업을 확인하고 DBA와 상의하세요.

설정 변경

롤백 시 함께 확인해야 할 설정.

  • 환경 변수: 이전 버전에서 필요한 환경 변수가 모두 있나요?
  • ConfigMap: 설정값이 이전 버전과 호환되나요?
  • Secret: 인증 정보가 변경되지 않았나요?

외부 서비스 연동

  • 외부 API 버전이 변경되었다면 호환성 확인
  • 다른 마이크로서비스와의 통신 프로토콜 확인

롤백 실패 시 대처

이전 이미지가 없는 경우

  • 레지스트리에서 삭제된 경우: 이전 버전 소스 코드에서 재빌드합니다.
  • 태그가 덮어쓰기된 경우: 이미지 다이제스트(SHA)로 복원을 시도합니다.
이미지 다이제스트로 복원

Harbor나 Docker Hub에서 이미지의 다이제스트(SHA256)를 확인하면 덮어쓰기된 태그도 특정 버전으로 복원할 수 있습니다.

Docker 재배포가 실패한 경우

배포 전 자동 백업 옵션이 켜져 있었다면, 백업 시점의 컨테이너/볼륨 상태로 복원할 수 있습니다. [백업 관리] 페이지에서 해당 백업을 선택해 복원을 진행하세요.

롤백 후에도 문제 지속

  1. 로그 분석: 애플리케이션 로그에서 근본 원인 파악
  2. 환경 확인: 환경 변수, ConfigMap, Secret 설정 검토
  3. 외부 의존성: 데이터베이스, 외부 API 상태 확인
  4. 더 이전 버전: 필요시 명령 실행 탭에서 더 이전 리비전으로 롤백

롤백 방지 모범 사례

롤백이 필요한 상황을 줄이기 위한 권장 사항입니다.

배포 전 검증 체크리스트

  • 빌드 단계: 테스트 통과, 보안 스캔 통과
  • 스테이징 단계: 기능 테스트, 성능 테스트
  • 카나리 단계: 일부 트래픽으로 실제 환경 검증
  • 프로덕션 단계: 모니터링 대시보드, 알림 설정

무중단 롤아웃 설정 (Kubernetes)

Kubernetes에서 안정적인 롤아웃을 위해 권장하는 설정.

  • Pod 시작 실패 대비: progressDeadlineSeconds 설정
  • Health Check: readinessProbe, livenessProbe 설정
  • 리소스 보호: resources.limits 설정
점진적 롤아웃

maxUnavailable: 0으로 설정하면 새 Pod이 Ready 상태가 될 때까지 기존 Pod을 유지합니다. 문제 발생 시 새 Pod이 Ready로 전환되지 않아 기존 Pod이 유지됩니다.


관련 가이드