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

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

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

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

시크릿(Secret)을 활용해 ‘민감한 값’을 환경 변수로 분리하기

JSCODE 박재성
JSCODE 박재성
2025-12-06
author
JSCODE 박재성
category
쿠버네티스
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 쿠버네티스 입문/실전
slug
use-secret-to-store-sensitive-env
type
post
updatedAt
Dec 6, 2025 04:46 AM

✅ 시크릿(Secret)이란?

시크릿(Secret)은 컨피그맵(ConfigMap)과 비슷하게 환경 변수를 분리해서 관리하는 오브젝트이다. 차이점은 시크릿(Secret)은 비밀번호와 같이 보안적으로 중요한 값을 관리하기 위한 오브젝트이다.
 
 

✅ 시크릿(Secret)을 활용해 ‘민감한 값’을 따로 분리하기

  1. 기존 매니페스트 파일 살펴보기
    1. spring-config.yaml
      apiVersion: v1 kind: ConfigMap # ConfigMap 기본 정보 metadata: name: spring-config # ConfigMap 이름 # Key, Value 형식으로 설정값 저장 data: my-account: jscode my-password: password123
      위 매니페스트 파일에서 my_password의 값이 보안적으로 중요한 값이라고 가정해보자. 그러면 my_password의 값은 컨피그맵(ConfigMap)이 아닌 시크릿(Secret)으로 관리해야 한다.
       
  1. 기존 매니페스트 파일 수정하기 / 새로운 매니페스트 파일 생성하기
    1. 수정 (spring-config.yaml)
      apiVersion: v1 kind: ConfigMap # ConfigMap 기본 정보 metadata: name: spring-config # ConfigMap 이름 # Key, Value 형식으로 설정값 저장 data: my-account: jscode my-password: password123
       
      생성 (spring-secret.yaml)
      apiVersion: v1 kind: Secret # Secret 기본 정보 metadata: name: spring-secret # Secret 이름 # Key, Value 형식으로 값 저장 stringData: my-password: my-secret-password
      • 참고) 시크릿이 잘 적용됐는 지 확인하기 위해 my-password 값 변경
       
      수정 (spring-deployment.yaml)
      apiVersion: apps/v1 kind: Deployment # Deployment 기본 정보 metadata: name: spring-deployment # Deployment 이름 # Deployment 세부 정보 spec: replicas: 5 # 생성할 파드의 복제본 개수 selector: matchLabels: app: backend-app # 아래에서 정의한 Pod 중 'app: backend-app'이라는 값을 가진 파드를 선택 # 배포할 Pod 정의 template: metadata: labels: # 레이블 (= 카테고리) app: backend-app spec: containers: - name: spring-container # 컨테이너 이름 image: spring-server # 컨테이너를 생성할 때 사용할 이미지 imagePullPolicy: IfNotPresent # 로컬에서 이미지를 먼저 가져온다. 없으면 레지스트리에서 가져온다. ports: - containerPort: 8080 # 컨테이너에서 사용하는 포트를 명시적으로 표현 env: - name: MY_ACCOUNT valueFrom: configMapKeyRef: name: spring-config # ConfigMap의 이름 key: my-account # ConfigMap에 설정되어 있는 Key값 - name: MY_PASSWORD valueFrom: secretKeyRef: name: spring-secret key: my-password
       
  1. 매니페스트 파일 반영하기
    1. $ kubectl apply -f spring-secret.yaml $ kubectl apply -f spring-config.yaml $ kubectl apply -f spring-deployment.yaml $ kubectl rollout restart deployment spring-deployment
 
  1. 잘 반영됐는 지 확인하기
    1. notion image
 
author
category
쿠버네티스
createdAt
Dec 6, 2025
series
비전공자도 이해할 수 있는 쿠버네티스 입문/실전
slug
type
series-footer
updatedAt
Dec 6, 2025 04:46 AM
📎
이 글은 비전공자도 이해할 수 있는 쿠버네티스 입문/실전 강의의 수업 자료 중 일부입니다.