본문 바로가기

Cloud

(Kubernetes) - application에 data 주입 4

반응형

🍳머리말

환경 변수로 container에 pod 정보를 노출하는 방법 설명글입니다.

k8s cluster가 있어야하며 node가 적어도 3개 있어야 합니다.


📕환경 변수로 container에 pod 정보 노출

📔 설명

pod 및 container field를 실행 중인 container에 노출하는 두 가지 방법이 있습니다.

  • 환경 변수
  • volume file

pod 및 container field를 노출하는 이 두 가지 방법을 downward API라고 합니다.

📔 예시

📑 pod field를 환경 변수의 값으로 사용

하나의 container를 가진 pod를 생성합니다. dap1-envars-pod.yaml

apiVersion: v1
kind: Pod
metadata:
  name: dapi-envars-fieldref
spec:
  containers:
    - name: test-container
      image: k8s.gcr.io/busybox
      command: [ "sh", "-c"]
      args:
      - while true; do
          echo -en '\n';
          printenv MY_NODE_NAME MY_POD_NAME MY_POD_NAMESPACE;
          printenv MY_POD_IP MY_POD_SERVICE_ACCOUNT;
          sleep 10;
        done;
      env:
        - name: MY_NODE_NAME
          valueFrom:
            fieldRef:
              fieldPath: spec.nodeName
        - name: MY_POD_NAME
          valueFrom:
            fieldRef:
              fieldPath: metadata.name
        - name: MY_POD_NAMESPACE
          valueFrom:
            fieldRef:
              fieldPath: metadata.namespace
        - name: MY_POD_IP
          valueFrom:
            fieldRef:
              fieldPath: status.podIP
        - name: MY_POD_SERVICE_ACCOUNT
          valueFrom:
            fieldRef:
              fieldPath: spec.serviceAccountName
  restartPolicy: Never

구성 file에서 5개의 환경 변수를 확인할 수 있습니다. env filed는 EnvVars의 배열입니다. 배열의 첫 번째 요소는MY_NODE_NAME 환경 변수가 파드의 spec.nodeName 필드에서 값을 가져오도록 지정합니다. 마찬가지로 다른 환경 변수도 파드 필드에서 이름을 가져옵니다. container의 field가 아닌 pod의 field라는 점을 주의합니다.

 

pod 생성

kubectl apply -f https://k8s.io/examples/pods/inject/dapi-envars-pod.yaml

또는

kubectl apply -f dapi-envars-pod.yaml

 

pod 생성 확인

kubectl get pods

 

container log 확인

kubectl logs dapi-envars-fieldref

출력결과

minikube
dapi-envars-fieldref
default
172.17.0.4
default

 

이러한 값이 log에 출력된 이유를 보려면 구성 file의 command 및 args field를 확인하면 됩니다. container가 시작되면 5개의 환경 변수 값을 stdout에 쓰여 10초마다 이를 반복합니다.

다음은 pod에서 실행 중인 container의 shell을 가져옵니다.

kubectl exec -it dapi-envars-fieldref -- sh

 

shell에서 환경 변수를 볼 수 있습니다.

/# printenv

 

출력은 특정 환경 변수에 pod field 값이 할당되었음을 보여줍니다.

MY_POD_SERVICE_ACCOUNT=default
...
MY_POD_NAMESPACE=default
MY_POD_IP=172.17.0.4
...
MY_NODE_NAME=minikube
...
MY_POD_NAME=dapi-envars-fieldref

📑 container field를 환경 변수의 값으로 사용

이전에는 pod field를 환경 변수의 값으로 사용해 보았습니다. 이번에는 container field를 사용해 봅니다.

dapi-envars-container.yaml

apiVersion: v1
kind: Pod
metadata:
  name: dapi-envars-resourcefieldref
spec:
  containers:
    - name: test-container
      image: k8s.gcr.io/busybox:1.24
      command: [ "sh", "-c"]
      args:
      - while true; do
          echo -en '\n';
          printenv MY_CPU_REQUEST MY_CPU_LIMIT;
          printenv MY_MEM_REQUEST MY_MEM_LIMIT;
          sleep 10;
        done;
      resources:
        requests:
          memory: "32Mi"
          cpu: "125m"
        limits:
          memory: "64Mi"
          cpu: "250m"
      env:
        - name: MY_CPU_REQUEST
          valueFrom:
            resourceFieldRef:
              containerName: test-container
              resource: requests.cpu
        - name: MY_CPU_LIMIT
          valueFrom:
            resourceFieldRef:
              containerName: test-container
              resource: limits.cpu
        - name: MY_MEM_REQUEST
          valueFrom:
            resourceFieldRef:
              containerName: test-container
              resource: requests.memory
        - name: MY_MEM_LIMIT
          valueFrom:
            resourceFieldRef:
              containerName: test-container
              resource: limits.memory
  restartPolicy: Never

 

구성 file에서는 4개의 환경 변수를 확인할 수 있습니다. env field는 EnvVars의 배열입니다. 배열의 첫 번째 요소는 MY_CPU_REQUEST 환경 변수가 test-container라는 컨테이너의 requests.cpu 필드에서 값을 가져오도록 지정합니다. 마찬가지로 다른 환경 변수도 컨테이너 필드에서 값을 가져옵니다.

 

pod 생성

kubectl apply -f https://k8s.io/examples/pods/inject/dapi-envars-container.yaml

또는(yaml file을 만들었다면)

kubectl apply -f dapi-envars-container.yaml

 

pod container 실행 확인

kubectl get pods

 

container log 확인

kubectl logs dapi-envars-resourcefieldref

 

출력은 선택 환경 변수의 값을 보여줍니다.

1
1
33554432
67108864

📕참조

https://kubernetes.io/ko/docs/tasks/inject-data-application/environment-variable-expose-pod-information/

 

환경 변수로 컨테이너에 파드 정보 노출하기

본 페이지는 파드에서 실행 중인 컨테이너에게 파드가 환경 변수를 사용해서 자신의 정보를 노출하는 방법에 대해 설명한다. 환경 변수는 파드 필드와 컨테이너 필드를 노출할 수 있다. 시작하

kubernetes.io