애플리케이션 노출법
배포한 애플리케이션을 노출하는 방법
- 간단한 방법
- port-forward
- HostPort
- hostNetwork
- NodePort
- LoadBalancer
- ExternalName
- ClusterIP, Headless
- Endpoints
- Ingress
간단한 방법(port-forward, HostPort, hostNetwork)
포트 포워딩
- 호스트 PC에서 가상 머신으로 접속 시 포트 포워딩 사용
data:image/s3,"s3://crabby-images/82b6b/82b6b3ea14368a12be8829b04a9a50685cf860d6" alt="애플리케이션 노출법 - 01 간단한 방법"
port-forward 옵션
data:image/s3,"s3://crabby-images/5347a/5347a50661a3d6f2b9fd0fbe83c067a9887e0b18" alt="애플리케이션 노출법 - 02 간단한 방법"
k port-forward fwd-chk-hn 80:80
: 마스터 노드의 80번 포트를 fwd-chk-hn
노드의 80번 포트로 포워딩- 노드가 재시작될 경우 포트 포워딩이 사라짐
HostPort
data:image/s3,"s3://crabby-images/66815/66815810b49c28a6bfb698e0262220538b000a07" alt="애플리케이션 노출법 - 03 간단한 방법"
containerPort
: 파드의 포트hostPort
: 노드의 포트- 노드의 IP와 포트를 알고 있어야 하므로 실용적이지 않음
HostNetwork
data:image/s3,"s3://crabby-images/4c2c8/4c2c8773bcc466b4d142fa9c7627d78abd59c0fa" alt="애플리케이션 노출법 - 04 간단한 방법"
- eth0을 그대로 쓸 수 있게 해주는 기능
- 클러스터의 노드에 직접 접속하므로 실용적이지 않음
노드포트(NodePort)
nodeport.yaml
data:image/s3,"s3://crabby-images/3de2a/3de2a0582eb7c612569a7851161928218dab1be2" alt="애플리케이션 노출법 - 05 노드포트"
selector
: 노출할 오브젝트nodePort
: 노드 포트, 미입력시 랜덤으로 지정port
: 서비스 포트targetPort
: 파드 포트
Overview
data:image/s3,"s3://crabby-images/28769/2876948e55f85c3c07a4c27b331c134bf3fa0684" alt="애플리케이션 노출법 - 06 노드포트"
- 사용자가 워커 노드의 NodePort 서비스 포트로 접속
- 연결을 NodePort 서비스로 보내줌
- NodePort는 워커 노드의 파드로 연결을 보냄
로드밸런서(LoadBalancer)
loadbalancer-11.yaml
data:image/s3,"s3://crabby-images/05917/05917c57091e07f03584f937b95ecfe60aa39781" alt="애플리케이션 노출법 - 07 로드밸런서"
port
: 서비스 포트targetPort
: 파드 포트- Metallb로 접근
loadbalancer-12.yaml
data:image/s3,"s3://crabby-images/ea16c/ea16c315831c73e3898deb40309863bfdd31e343" alt="애플리케이션 노출법 - 08 로드밸런서"
Overview
data:image/s3,"s3://crabby-images/c69ce/c69ce139aa0069ac86591051c6dfd67c093c1388" alt="애플리케이션 노출법 - 09 로드밸런서"
- 사용자는
ConfigMap
을 통하여 EXT IP로 접속 - 내부의 파드로 연결됨
외부이름(ExternalName)
externalname-1.yaml
data:image/s3,"s3://crabby-images/7efbe/7efbee4256c3c0ba67a0cb98764669ff39affb48" alt="애플리케이션 노출법 - 10 외부이름"
externalname-2.yaml
data:image/s3,"s3://crabby-images/3af97/3af97a26199542a3186854be28a2f4c734bffbfc" alt="애플리케이션 노출법 - 11 외부이름"
Overview
data:image/s3,"s3://crabby-images/8c31e/8c31ed55ba12358e26de28b7f8d064f1681eda89" alt="애플리케이션 노출법 - 12 외부이름"
- 컨테이너 내부에서 외부 도메인을 aliasing 하는 데에 사용
클러스터주소(ClusterIP)와 헤드리스(Headless)
clusterip.yaml
data:image/s3,"s3://crabby-images/830b5/830b543f446578fc5cec7938d375bcc94ed86cce" alt="애플리케이션 노출법 - 13 클러스터IP와 헤드리스"
headless.yaml
data:image/s3,"s3://crabby-images/82b37/82b37fea868551f98bdb6699332bd8adabfeb6a8" alt="애플리케이션 노출법 - 14 클러스터IP와 헤드리스"
- 클러스터 IP를
None
으로 지정하면 Headless
가 됨
클러스터주소와 헤드리스 비교
- 헤드리스를 사용할 경우 IP 주소를 소진하지 않고 스테이트풀셋을 연결할 수 있음
- 스테이트풀셋 각각의 파드는 고정된 이름을 갖고 각각의 목적을 갖고 있도록 설계할 수 있음
NodePort
나 LoadBalancer
를 사용할 경우 각각의 파드에 대한 접속을 통제하기 어려움- 따라서 헤드리스를 사용하여 스테이트풀셋에 대한 연결을 관리
sts-svc-domain-headless.yaml
data:image/s3,"s3://crabby-images/61a7f/61a7ff38655f767a1502a6a7098bfc817f313f0e" alt="애플리케이션 노출법 - 15 클러스터IP와 헤드리스"
nslookup sts-chk-hn-0.sts-svc.domain
nslookup sts-chk-hn-1.sts-svc.domain
nslookup sts-chk-hn-2.sts-svc.domain
- 위와 같은 명령어로 스테이트풀셋 내 각각의 노드에 서비스 이름으로 접근 가능
serviceName
을 통하여 노드와 헤드리스가 결합됨LoadBalancer
로 노출은 가능하나 스테이트풀셋의 목적에 부합하지 않으므로 자주 사용하지는 않음
엔드포인트(Endpoints)
loadbalancer.yaml의 엔드포인트
data:image/s3,"s3://crabby-images/a14f4/a14f4d4dae1096da6010b39ac07fed8a7bdc9d01" alt="애플리케이션 노출법 - 16 엔드포인트"
- 파드의 개수만큼 엔드포인트가 자동으로 생성됨
- 외부에 노출된 서비스를 통하여 도달하는 파드의 IP를 일컬음
service-endpoints.yaml
data:image/s3,"s3://crabby-images/33f1c/33f1cd5b8c91fb4f02c2ab0abc5729e8d3826e1a" alt="애플리케이션 노출법 - 17 엔드포인트"
metadata.name
을 클러스터와 일치시켜 수동으로 엔드포인트 생성- 위와 같이 로드밸런서의 IP를 엔드포인트로 지정할 경우 로드밸런서를 거쳐 최종적으로 파드에 도달
인그레스(Ingress)
NodePort와 인그레스
data:image/s3,"s3://crabby-images/8a212/8a2120378990381f7597d0f38c63e05d6f780249" alt="애플리케이션 노출법 - 18 인그레스"
- 사용자가 워커 노드의 포트로 접근
- NodePort 서비스로 이동
- 접속 경로에 따라 해당하는 파드로 이동
LoadBalancer와 인그레스
data:image/s3,"s3://crabby-images/5d3b3/5d3b3d2ead92399fa8168b8dd94d82d6851fadd8" alt="애플리케이션 노출법 - 19 인그레스"
- 사용자가 로드밸런서 서비스에 접근
- 접속 경로에 따라 서비스로 이동
- 각각의 서비스의 엔드포인트로 이동
ingress.yaml
data:image/s3,"s3://crabby-images/7e627/7e627f4fbf1c6c32e198fa49a505de4ba3677633" alt="애플리케이션 노출법 - 23 인그레스"
레이블(labels)과 애너테이션(annotations)의 차이
data:image/s3,"s3://crabby-images/36f2f/36f2fcf0e804844b97b3ae9d0f4af7287aa34423" alt="애플리케이션 노출법 - 24 인그레스 애플리케이션 노출법 - 24 인그레스"
Labels
: 관리자, 개발자가 인식하는 부가 정보Annotation
: 시스템이 인식하는 부가 정보
각 타입별 ingress controller 설정의 차이
data:image/s3,"s3://crabby-images/3add7/3add7c5a20734625b35af7bfe797c28dc6df790f" alt="애플리케이션 노출법 - 25 인그레스"
NodePort
의 경우 무작위로 지정되나 실습의 편의를 위해 spec 수정LoadBalancer
는 포트를 지정할 필요 없음