Zuul
Table of Contents
1. Netflix Zuul 개요
마이크로서비스 아키텍처에서 의미
Netflix Zuul 설계 목적
Netflix Zuul Architecture
Zuul in Netflix’s Cloud Architecture
Netflix Zuul 2.0 Architecture
Netflix Zuul 필요 배경
2. Netflix Zuul Features
Netflix Zuul 동작방식
Routing Rules
Filters
Service Discovery
Load Balancing
3. Getting Started
Spring boot project 생성
Filter
RouteLocator
1. Netflix Zuul 개요
마이크로서비스 아키텍처에서 의미
정의
API Gateway 또는 API Service, Edge Service
역할
마이크로서비스 아키텍처에서 여러 클라이언트 요청을 적절한 서비스로 프록시하거나 라우팅하기 위한 서비스
Netflix Zuul 설계 목적
정의
JVM-based router and Server-side load balancer
목적
동적 라우팅, 모니터링, 회복 탄력성, 보안 기능을 지원 (Filters를 통한 구현)
필요에 따라 여러 개의 Amazon Auto Scaling Groups로 요청을 라우팅 (Ribbon을 통한 구현)
Netflix Zuul Architecture
Zuul in Netflix’s Cloud Architecture
Netflix Zuul 2.0 Architecture
Netflix Zuul (API Service) 필요 배경 (추가정리 TBD, 그림변경 필요)
Monolithic 에서 Microservice Architecture 분산 서비스 환경으로의 변화
하나의 서버에서 하나의 어플리케이션으로 동작하는 모놀리틱 아키텍처와 달리 마이크로서비스 아키텍처는 클라이언트 요청을 처리하기 위해 작게 나뉘어진 여러 개의 서비스가 서로 커뮤니케이션하고 협업하는 소프트웨어 아키텍처 패턴이다.
특징
클라이언트와 백엔드 서비스간 커뮤니케이션 방법의 변화
Monolithic: 어플리케이션 내부에서 객체 주입, 메서드 호출 등을 통해 서로 다른 도메인 서비스와 협업하여 데이터 생성
Microservices: 클라이언트가 하나 이상의 서비스와 직접 통신해서 데이터 생성
기능적 측면에서 변화
백엔스 서비스를 대상으로 인증, 권한, CORS 관리 등과 같은 공통 관심사 로직을 클라이언트에서 분리
백엔드 서비스들의 다양한 통신 프로토콜(HTTP, AMQP 등) 사용에 대한 지원
다양한 클라이언트(web/mobile browser, native mobile app 등) 특성에 맞는 다양한 데이터 포맷 지원
인프라 측면
클라우드 환경에서 Auto Scaling과 같은 기능을 이용해 서비스 인스턴스를 트래픽에 따라 동적으로 생성/운영하거나 컨테이너로 배포하면서 인스턴스의 위치(host,port)가 동적으로 변한다.
시간이 지남에 따라 서비스가 합쳐지거나 쪼개질 수 있다
2. Netflix Zuul Features
Netflix Zuul 동작방식
(그림 TBD) front-end -----routing rules:shard traffic with path------ zuul -----service discovery:instance lookup---- back-end REST API
Routing Rules
front-end로부터 들어온 HTTP request를 prefix or path에 따라 특정 service로 라우팅하기 위한 규칙을 정의
Filters
클라이언트가 보낸 요청을 라우팅 하기 전, 라우팅할 때, 라우팅한 후 응답을 돌려 받았을 때 필요한 작업을 수행
Filter 구성 요소
설명
Type
pre, route, post (ZuulFilter를 상속받아 구현)
Order
filter 실행 순서를 결정 (filterOrder())
Criteria
filter 실행 여부 결정 (shouldFilter())
Action
filter criteria 만족 시 실행할 비즈니스 로직 (run())
Pre filter 예시
Service Discovery
path를 매핑할 실제 서비스 인스턴스 위치를 찾는 방법
Eureka (dynamic)
```yml
zuul:
routes:
users:
eureka: client: serviceUrl: defaultZone: http://localhost:8761/eureka/
Load Balancing
round-robin, weighted response time, availability이 있음
Other 2.0 features
Connection Pooling
Status Categories
Retries
Request Passport
Request Attempts
Origin Concurrency Protection
HTTP/2
Mutual TLS
Proxy Protocol
GZip
3. Getting Started
Zuul
Spring boot project 생성
pom.xml에 zuul, eureka-client dependency 추가
configuration - application.yml 수정
서비스명 zuul-sevice로 설정
Gateway의 라우팅 정보 설정
Eureka client 등록
@EnableZuulProxy annotation 추가를 통해 Zuul Proxy 선언
Gateway 도 Eureka Client로 등록
Fallback 처리를 위한 Provider 등록
Filter 등록
Filter
Filter 생성 및 등록
RouteLocator
RouteLocator를 통해 Zuul 설정에 등록된 route 정보를 확인할 수 있다.
RouteLocator 생성 및 등록
```java public class CoeZuulApplication {
@Autowired private ServerProperties serverProperties; @Autowired private ZuulProperties zuulProperties;
@Bean public RouteLocater routeLocater() { return new RouteLocater(serverProperties.getServlet().getServletPrefix(), zuulProperties); //zuul의 route 설정 사용한다. }
public static void main(String[] args) { SpringApplication.run(ZuulApplication.class, args); }
}
Last updated