2.4. AWS 로드 밸런서 운영자 설치
AWS 로드 밸런서 운영자는 AWS 로드 밸런서 컨트롤러를 배포하고 관리합니다. OpenShift Container Platform 웹 콘솔이나 CLI를 사용하여 OperatorHub에서 AWS Load Balancer Operator를 설치할 수 있습니다.
2.4.1. 웹 콘솔을 사용하여 AWS Load Balancer Operator 설치 링크 복사링크가 클립보드에 복사되었습니다!
웹 콘솔을 사용하여 AWS Load Balancer Operator를 설치할 수 있습니다.
사전 요구 사항
-
클러스터 관리자
권한이 있는 사용자로 OpenShift Container Platform 웹 콘솔에 로그인했습니다. - 귀하의 클러스터는 플랫폼 유형 및 클라우드 공급자로 AWS로 구성되었습니다.
- 보안 토큰 서비스(STS) 또는 사용자 제공 인프라를 사용하는 경우 관련 준비 단계를 따르세요. 예를 들어 AWS 보안 토큰 서비스를 사용하는 경우 "AWS 보안 토큰 서비스(STS)를 사용하여 클러스터에서 AWS 로드 밸런서 운영자 준비"를 참조하세요.
프로세스
-
OpenShift Container Platform 웹 콘솔에서 Operators
OperatorHub 로 이동합니다. - AWS Load Balancer Operator를 선택합니다. 키워드로 필터링 텍스트 상자를 사용하거나 필터 목록을 사용하여 운영자 목록에서 AWS Load Balancer 운영자를 검색할 수 있습니다.
-
aws-load-balancer-operator
네임스페이스를 선택합니다. 설치 운영자 페이지에서 다음 옵션을 선택하세요.
- 채널을 stable-v1 로 업데이트합니다.
- 설치 모드 는 클러스터의 모든 네임스페이스(기본값) 입니다.
-
네임스페이스를
aws-load-balancer-operator
로 설치했습니다 .aws-load-balancer-operator
네임스페이스가 없으면 Operator 설치 중에 생성됩니다. - 업데이트 승인을 자동 또는 수동 으로 선택합니다. 기본적으로 업데이트 승인은 자동 으로 설정됩니다. 자동 업데이트를 선택하면 Operator Lifecycle Manager(OLM)가 어떠한 개입 없이 실행 중인 Operator 인스턴스를 자동으로 업그레이드합니다. 수동 업데이트를 선택하면 OLM에서 업데이트 요청을 생성합니다. 클러스터 관리자는 해당 업데이트 요청을 수동으로 승인하여 Operator를 새 버전으로 업데이트해야 합니다.
- 설치를 클릭합니다.
검증
- 설치된 운영자 대시보드에서 AWS Load Balancer 운영자의 상태가 성공 으로 표시되는지 확인합니다.
2.4.2. CLI를 사용하여 AWS Load Balancer Operator 설치 링크 복사링크가 클립보드에 복사되었습니다!
CLI를 사용하여 AWS Load Balancer Operator를 설치할 수 있습니다.
사전 요구 사항
-
클러스터 관리자
권한이 있는 사용자로 OpenShift Container Platform 웹 콘솔에 로그인했습니다. - 귀하의 클러스터는 플랫폼 유형 및 클라우드 공급자로 AWS로 구성되었습니다.
-
OpenShift CLI(
oc
)에 로그인했습니다.
프로세스
네임스페이스
객체를 만듭니다.네임스페이스
객체를 정의하는 YAML 파일을 만듭니다.namespace.yaml
파일 예apiVersion: v1 kind: Namespace metadata: name: aws-load-balancer-operator
apiVersion: v1 kind: Namespace metadata: name: aws-load-balancer-operator
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 다음 명령을 실행하여
네임스페이스
객체를 만듭니다.oc apply -f namespace.yaml
$ oc apply -f namespace.yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
OperatorGroup
오브젝트를 생성합니다.OperatorGroup
객체를 정의하는 YAML 파일을 만듭니다.operatorgroup.yaml
파일 예시Copy to Clipboard Copied! Toggle word wrap Toggle overflow 다음 명령을 실행하여
OperatorGroup
객체를 만듭니다.oc apply -f operatorgroup.yaml
$ oc apply -f operatorgroup.yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
구독
객체를 만듭니다.구독
객체를 정의하는 YAML 파일을 만듭니다.subscription.yaml
파일 예시Copy to Clipboard Copied! Toggle word wrap Toggle overflow 다음 명령을 실행하여 서브스크립션 오브젝트를 생성합니다.
oc apply -f subscription.yaml
$ oc apply -f subscription.yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow
검증
구독에서 설치 계획의 이름을 가져옵니다.
oc -n aws-load-balancer-operator \ get subscription aws-load-balancer-operator \ --template='{{.status.installplan.name}}{{"\n"}}'
$ oc -n aws-load-balancer-operator \ get subscription aws-load-balancer-operator \ --template='{{.status.installplan.name}}{{"\n"}}'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 설치 계획의 상태를 확인하세요.
oc -n aws-load-balancer-operator \ get ip <install_plan_name> \ --template='{{.status.phase}}{{"\n"}}'
$ oc -n aws-load-balancer-operator \ get ip <install_plan_name> \ --template='{{.status.phase}}{{"\n"}}'
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 출력은
완료
되어야 합니다.
2.4.3. AWS 로드 밸런서 컨트롤러 생성 링크 복사링크가 클립보드에 복사되었습니다!
클러스터에 AWSLoadBalancerController
객체의 단일 인스턴스만 설치할 수 있습니다. CLI를 사용하여 AWS Load Balancer Controller를 생성할 수 있습니다. AWS Load Balancer Operator는 리소스라는 이름의 클러스터
만 조정합니다.
사전 요구 사항
-
echoserver
네임스페이스를 생성했습니다. -
OpenShift CLI(
oc
)에 액세스할 수 있습니다.
프로세스
AWSLoadBalancerController
객체를 정의하는 YAML 파일을 만듭니다.sample-aws-lb.yaml
파일 예시Copy to Clipboard Copied! Toggle word wrap Toggle overflow - 1
AWSLoadBalancerController
객체를 정의합니다.- 2
- AWS Load Balancer Controller 이름을 정의합니다. 이 인스턴스 이름은 모든 관련 리소스에 접미사로 추가됩니다.
- 3
- AWS Load Balancer Controller에 대한 서브넷 태그 지정 방법을 구성합니다. 유효한 값은 다음과 같습니다.
-
자동
: AWS Load Balancer Operator는 클러스터에 속하는 서브넷을 결정하고 이에 적절한 태그를 지정합니다. 내부 서브넷 태그가 내부 서브넷에 없으면 운영자는 역할을 올바르게 결정할 수 없습니다. -
수동
: 클러스터에 속한 서브넷에 적절한 역할 태그를 수동으로 지정합니다. 사용자가 제공한 인프라에 클러스터를 설치한 경우 이 옵션을 사용하세요.
-
- 4
- AWS 리소스를 프로비저닝할 때 AWS Load Balancer Controller에서 사용하는 태그를 정의합니다.
- 5
- 수신 클래스 이름을 정의합니다. 기본값은
alb
입니다. - 6
- AWS Load Balancer Controller의 복제본 수를 지정합니다.
- 7
- AWS Load Balancer Controller에 대한 추가 기능으로 주석을 지정합니다.
- 8
alb.ingress.kubernetes.io/wafv2-acl-arn
주석을 활성화합니다.
다음 명령을 실행하여
AWSLoadBalancerController
객체를 만듭니다.oc create -f sample-aws-lb.yaml
$ oc create -f sample-aws-lb.yaml
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 배포
리소스를 정의하는 YAML 파일을 만듭니다.sample-aws-lb.yaml
파일 예시Copy to Clipboard Copied! Toggle word wrap Toggle overflow 서비스
리소스를 정의하는 YAML 파일을 만듭니다.service-albo.yaml
파일 예시Copy to Clipboard Copied! Toggle word wrap Toggle overflow Ingress
리소스를 정의하는 YAML 파일을 만듭니다.ingress-albo.yaml
파일 예시Copy to Clipboard Copied! Toggle word wrap Toggle overflow
검증
다음 명령을 실행하여
HOST
변수에Ingress
리소스 상태를 저장합니다.HOST=$(oc get ingress -n echoserver echoserver --template='{{(index .status.loadBalancer.ingress 0).hostname}}')
$ HOST=$(oc get ingress -n echoserver echoserver --template='{{(index .status.loadBalancer.ingress 0).hostname}}')
Copy to Clipboard Copied! Toggle word wrap Toggle overflow 다음 명령을 실행하여
Ingress
리소스의 상태를 확인하세요.curl $HOST
$ curl $HOST
Copy to Clipboard Copied! Toggle word wrap Toggle overflow