인프런 워밍업클럽 4기 - 데브옵스 스터디
[미션3] Application 기능으로 이해하기 - Configmap, Secret
응용1 : Configmap의 환경변수들을 Secret을 사용해서 작성하고, App에서는 같은 결과가 나오도록 확인해 보세요.
☞ Secret을 이렇게 사용하는 경우는 별로 보지 못했습니다. 여러가지 방법으로 Secret을 만들어본다는데 의의를 두시면 됩니다.
Step1. Secret 생성 (1) - dashboard
apiVersion: v1
kind: Secret
metadata:
namespace: anotherclass-123
name: api-tester-1231-properties
labels:
part-of: k8s-anotherclass
component: backend-server
name: api-tester
instance: api-tester-1231
version: 1.0.0
managed-by: dashboard
stringData:
spring_profiles_active: "dev"
application_role: "ALL"
postgresql_filepath: "/usr/src/myapp/datasource/dev/postgresql-info.yaml"
Step1 - Secret 생성 (2) - kubectl #1
kubectl apply -f - <<EOF
apiVersion: v1
kind: Secret
metadata:
namespace: anotherclass-123
name: api-tester-1231-properties
labels:
part-of: k8s-anotherclass
component: backend-server
name: api-tester
instance: api-tester-1231
version: 1.0.0
managed-by: dashboard
data:
spring_profiles_active: $(echo -n "dev" | base64 -w0)
application_role: $(echo -n "ALL" | base64 -w0)
postgresql_filepath: $(echo -n "/usr/src/myapp/datasource/dev/postgresql-info.yaml" | base64 -w0)
EOF


Step2. Deployment의 envFrom.secretRef 부분 업데이트
apiVersion: apps/v1
kind: Deployment
metadata:
namespace: anotherclass-123
name: api-tester-1231
spec:
template:
spec:
nodeSelector:
kubernetes.io/hostname: k8s-master
containers:
- name: api-tester-1231
image: 1pro/api-tester:v1.0.0
envFrom:
- secretRef:
name: api-tester-1231-properties
Apply kubectl
kubectl edit -n anotherclass-123 deployments.apps api-tester-1231
응용2 : 반대로 Secret의 DB정보를 Configmap으로 만들어보고 App을 동작시켜 보세요
☞ Configmap을 Volume에 연결해서 쓰는 케이스는 매우 많습니다.
apiVersion: v1
kind: ConfigMap
metadata:
namespace: anotherclass-123
name: api-tester-1231-postgresql
labels:
part-of: k8s-anotherclass
component: backend-server
name: api-tester
instance: api-tester-1231
version: 1.0.0
managed-by: dashboard
data:
postgresql-info.yaml: |
driver-class-name: "org.postgresql.Driver"
url: "jdbc:postgresql://postgresql:5431"
username: "dev"
password: "dev123"
Step2. Deployment의 volumeMounts.name과 volumes 부분 업데이트
apiVersion: apps/v1
kind: Deployment
metadata:
namespace: anotherclass-123
name: api-tester-1231
spec:
template:
spec:
nodeSelector:
kubernetes.io/hostname: k8s-master
containers:
- name: api-tester-1231
image: 1pro/api-tester:v1.0.0
volumeMounts:
- name: configmap-datasource
mountPath: /usr/src/myapp/datasource/dev
volumes:
- name: configmap-datasource
configMap:
name: api-tester-1231-postgresql
Apply kubectl
kubectl edit -n anotherclass-123 deployments.apps api-tester-1231
Deployment.yaml을 적용하고 나면 신규 Pod가 생성되는데, 해당 Pod의 상세 내용을 보면 Mounts 부분에 ConfigMap이 등록된 것을 확인할 수 있다.
'인프런 워밍업클럽' 카테고리의 다른 글
Docker와 Containerd 명령 실습 (2) | 2025.06.17 |
---|---|
Application 기능으로 이해하기 - PVC/PV, Deployment, Service, HPA (3) | 2025.06.08 |
Application 기능으로 이해하기 - Probe (0) | 2025.06.04 |
쿠버네티스 설치 구간별 상태 확인 (0) | 2025.06.01 |