로드밸런서 생성/삭제하기

페이지 이동경로

로드밸런서 생성 및 삭제하기

로드밸런서(Load Balancer)는 시스템으로 유입되는 대량의 트래픽을 다수의 서버로 분산시켜 안정적인 서비스 운영을 지원합니다. Kubernetes Engine 서비스에서 로드밸런서를 생성하는 방법은 다음과 같습니다.

로드밸런서 생성하기

Kubernetes Engine 서비스에서 로드밸런서를 생성하는 방법은 다음과 같습니다.

안내
현재(2022년 10월 기준) 사설 IP를 갖는 Internal 로드밸런서만 생성할 수 있습니다.

Step 1. kubectl 설치 및 제어 설정

Kubernetes에서 Service 객체를 생성하기 위해서는 kubectl를 설치하고, 클러스터에 대한 kubectl 제어를 설정해야 합니다. kubectl 설치 및 제어 설정에 대한 자세한 설명은 Kubernetes Engine > kubectl 제어 설정하기 문서를 참고하시기 바랍니다.

Step 2. 로드밸런서 타입 서비스 명세 확인

로드밸런서 타입 서비스의 명세를 확인합니다. app: nginx와 연동된 로드밸런서 타입 서비스 YAML 파일에서 다음의 2개 항목을 확인합니다.

항목 설명
type 서비스 타입
- LoadBalancer 로 지정
annotations 사설 IP를 갖는 Internal 로드밸런서를 생성
- service.beta.kubernetes.io/openstack-internal-load-balancer: "true" 로 지정

코드 예제 로드밸런서 타입 서비스 명세 확인

kind: Service
apiVersion: v1
metadata:
  name: default-http-nginx-service
  annotations:
    service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
spec:
  selector:
    app: nginx
  type: LoadBalancer
  ports:
  - name: http
    port: 80
    targetPort: 80

로드밸런서 타입 서비스 생성 예제

예제를 통해 간단한 Nginx 애플리케이션을 로드밸런서 타입 서비스로 생성하는 방법을 설명합니다.

코드 예제 로드밸런서 타입 서비스 생성

apiVersion: apps/v1
kind: Deployment
metadata:
  name: internal-http-nginx-deployment
spec:
  replicas: 2
  selector:
    matchLabels:
      app: nginx
  template:
    metadata:
      labels:
        app: nginx
    spec:
      containers:
      - name: nginx
        image: nginx
        ports:
        - containerPort: 80
---
kind: Service
apiVersion: v1
metadata:
  name: default-http-nginx-service
  annotations:
    service.beta.kubernetes.io/openstack-internal-load-balancer: "true"
spec:
  selector:
    app: nginx
  type: LoadBalancer
  ports:
  - name: http
    port: 80
    targetPort: 80
  1. 다음의 명령어를 통해 배포를 진행합니다.
    • 실행 시 카카오 i 클라우드의 로드밸런서가 자동으로 생성됩니다. 로드밸런스 생성까지 약 5분 정도 소요될 수 있습니다.

    코드 예제 배포 진행 명령어

     kubectl --kubeconfig=$KUBE_CONFIG apply -f https://raw.githubusercontent.com/kakaoicloud-guide/kubernetes-engine/main/guide-samples/createLB/lb-nginx.yml
    
  2. 생성된 로드밸런서의 사설 IP 주소를 확인하기 위해 다음의 명령어를 실행하여 EXTERNAL-IP 열을 확인합니다. 생성 전까지 Pending 상태가 지속될 수 있습니다.

    코드 예제 로드밸런서 사설 IP 주소 확인

     kubectl --kubeconfig=$KUBE_CONFIG get svc default-http-nginx-service
    

    코드 예제 주소 확인 실행 결과

     NAME                         TYPE           CLUSTER-IP      EXTERNAL-IP     PORT(S)        AGE
     default-http-nginx-service   LoadBalancer   {CLUSTER-IP}   {EXTERNAL-IP}   80:32245/TCP   7h15m
    
  3. 다음 명령어를 통해 EXTERNAL-IP로 트래픽이 정상적으로 수신되는지 확인할 수 있습니다.

    코드 예제 EXTERNAL-IP로 트래픽 수신 확인

     curl {EXTERNAL-IP}
    

    코드 예제 트래픽 수신 확인 실행 결과

     <!DOCTYPE html>
     <html>
     <head>
     <title>Welcome to nginx!</title>
     <style>
         body {
             width: 35em;
             margin: 0 auto;
             font-family: Tahoma, Verdana, Arial, sans-serif;
         }
     </style>
     </head>
     <body>
     <h1>Welcome to nginx!</h1>
     <p>If you see this page, the nginx web server is successfully installed and
     working. Further configuration is required.</p>
    
     <p>For online documentation and support please refer to
     <a href="http://nginx.org/">nginx.org</a>.<br/>
     Commercial support is available at
     <a href="http://nginx.com/">nginx.com</a>.</p>
    
     <p><em>Thank you for using nginx.</em></p>
     </body>
     </html>
    

로드밸런서 삭제하기

더 이상 사용하지 않는 로드밸런서를 삭제할 수 있습니다. 로드밸런서 타입으로 생성된 Service 객체는 자동으로 생성된 카카오 i 클라우드 로드밸런서와 연동됩니다. 해당 Service를 삭제하는 경우 연동된 로드밸런서도 함께 삭제됩니다.

코드 예제 Service 삭제

kubectl --kubeconfig=$KUBE_CONFIG delete svc default-http-nginx-service