JSCODE Logo
프로그래밍 과외블로그후기멘토진
회사명 : JSCODE대표 : 박재성사업자 등록번호 : 244-22-01557통신판매업 : 제 2023-인천미추홀-0381 호
학원 명칭 : 제이에스코드(JSCODE)원격학원학원설립ㆍ운영 등록번호 : 제6063호

서울특별시 구로구 경인로 20가길 11(오류동, 아델리아)

Copyright ⓒ 2025 JSCODE - 최상위 현업 개발자들의 프로그래밍 교육 All rights reserved.

이용약관개인정보처리방침
← 블로그 목록으로 돌아가기

[예제] 디플로이먼트(Deployment)를 활용해 MySQL 실행시키기

JSCODE 박재성
JSCODE 박재성
2025-12-06
author
JSCODE 박재성
category
쿠버네티스
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 쿠버네티스 입문/실전
slug
example-run-mysql-with-deployment
type
post
updatedAt
Dec 6, 2025 04:46 AM

✅ 디플로이먼트(Deployment) 활용해 MySQL 실행시키기

  1. 매니페스트 파일 생성하기
    1. mysql-deployment.yaml
      apiVersion: apps/v1 kind: Deployment # Deployment 기본 정보 metadata: name: mysql-deployment # Deployment 이름 # Deployment 세부 정보 spec: replicas: 1 # 생성할 파드의 복제본 개수 selector: matchLabels: app: mysql-db # 아래에서 정의한 Pod 중 'app: mysql-db'이라는 값을 가진 파드를 선택 # 배포할 Pod 정의 template: metadata: labels: # 레이블 (= 카테고리) app: mysql-db spec: containers: - name: mysql-container # 컨테이너 이름 image: mysql # 컨테이너를 생성할 때 사용할 이미지 ports: - containerPort: 3306 # 컨테이너에서 사용하는 포트를 명시적으로 표현 env: - name: MYSQL_ROOT_PASSWORD value: password123 valueFrom: secretKeyRef: name: mysql-secret key: mysql-root-password - name: MYSQL_DATABASE value: kub-practice valueFrom: configMapKeyRef: name: mysql-config key: mysql-database
       
      mysql-secret.yaml
      apiVersion: v1 kind: Secret # Secret 기본 정보 metadata: name: mysql-secret # Secret 이름 # Key, Value 형식으로 값 저장 stringData: mysql-root-password: password123
       
      mysql-config.yaml
      apiVersion: v1 kind: ConfigMap # ConfigMap 기본 정보 metadata: name: mysql-config # ConfigMap 이름 # Key, Value 형식으로 설정값 저장 data: mysql-database: kub-practice
       
      mysql-service.yaml
      apiVersion: v1 kind: Service # Service 기본 정보 metadata: name: mysql-service # Service 이름 # Service 세부 정보 spec: type: NodePort # Service의 종류 selector: app: mysql-db # 실행되고 있는 파드 중 'app: mysql-db'이라는 값을 가진 파드와 서비스를 연결 ports: - protocol: TCP # 서비스에 접속하기 위한 프로토콜 port: 3306 # 쿠버네티스 내부에서 Service에 접속하기 위한 포트 번호 targetPort: 3306 # 매핑하기 위한 파드의 포트 번호 nodePort: 30002 # 외부에서 사용자들이 접근하게 될 포트 번호
       
  1. 매니페스트 기반으로 오브젝트 생성하기
    1. $ kubectl apply -f mysql-secret.yaml $ kubectl apply -f mysql-config.yaml $ kubectl apply -f mysql-deployment.yaml $ kubectl apply -f mysql-service.yaml
       
  1. DB 접속해보기
    1. notion image
      notion image
       
  1. 새로운 데이터베이스 생성하기
    1. notion image
 
 

✅ MySQL 재시작시키기

🧑🏻‍🏫
여기서 MySQL가 이유 모를 장애로 서비스가 중단됐다고 가정하자. 그래서 디플로이먼트를 다시 시작해야 하는 상황이라고 해보자.
  1. 디플로이먼트 재시작하기
    1. $ kubectl rollout restart deployment mysql-deployment
       
  1. 데이터베이스 다시 확인해보기
    1. notion image
       
데이터베이스를 확인해보면 이전에 만들었던 new-db라는 데이터베이스가 없어졌다. 실제 데이터베이스에서는 데이터가 없어져서는 안 된다. 데이터가 보존되도록 볼륨(Volume)을 설정해보자.
 
author
category
쿠버네티스
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 쿠버네티스 입문/실전
slug
type
series-footer
updatedAt
Dec 6, 2025 04:46 AM
📎
이 글은 비전공자도 이해할 수 있는 쿠버네티스 입문/실전 강의의 수업 자료 중 일부입니다.