Spring/SpringBoot-MSA

SpringBoot MSA (5) - API Gateway Service

ChrisMare 2023. 10. 3. 21:08

이전까지 Service Discovery에 여러 인스턴스를 등록하는 과정을 진행했지만,

이러할 경우 각 포트와 URI 정보가 달아지기 때문에 배포를 하더라도 클라이언트측에서도 같이 반영되어야되는 단점이 존재합니다.

 

따라서, 

 

중간에 API Gateway를 두어서 클라이언트가 API Gateway에 호출하여 호출정보에 맞는 각 인스턴스로 맵핑해주는 역할이 필요합니다.

 

API Gateway Service를 한다면,

  1. 인증 및 권한 부여
  2. 서비스 검색 통합
  3. 응답 캐싱
  4. 정책, 회로 차단기 및 Qos 다시 시도
    1. 중간 서비스에 문제가 발생할 경우 간단하게 막을 수 있다.
  5. 속도 제한
  6. 부하 분산
  7. 로깅, 추적, 상관 관계
  8. 헤더, 쿼리 문자열 및 청구 변환
  9. IP 허용 목록에 추가

등의 작업을 할 수 있습니다.

 

우선 클라이언트 서비스 first, second 서비스 두가지를 만들어보겠습니다.

 

기존과 동일하게 프로젝트는

java 11

maven

Eureka Discovery Client, Lombok 정도만 추가하여 생성

 

application.yml (first-service 프로젝트)

server:
  port: 8081

spring:
  application:
    name: my-first-service

eureka:
  client:
    fetch-registry: false
    register-with-eureka: false

FirstServiceController.java (Test)

package com.example.firstservice;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

// http://localhost:8081/welcome
// http://localhost:8081/first-service/welcome
@RestController
@RequestMapping("/first-service")
public class FirstServiceController {

    @GetMapping("/welcome")
    public String welcome() {
        return "Welcome to the First Service";
    }
}

 

application.yml (second-service 프로젝트)

server:
  port: 8082

spring:
  application:
    name: my-second-service

eureka:
  client:
    fetch-registry: false
    register-with-eureka: false

SecondServiceController.java (Test)

package com.example.secondservice;

import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

// http://localhost:8082/welcome
// http://localhost:8082/second-service/welcome
@RestController
@RequestMapping("/second-service")
public class SecondServiceController {

    @GetMapping("/welcome")
    public String welcome() {
        return "Welcome to the Second Service";
    }
}


Spring Cloud
로 진행해보겠습니다.

 

 

 

application.yml 설정

위에서 생성한 클라이언트 서비스 (first-service, second-service) 로 연결설정

server:
  port: 8000

eureka:
  client:
    register-with-eureka: false
    fetch-registry: false
    service-url:
      defaultZone: http://localhost:8761/eureka

spring:
  application:
    name: apigateway-service
  cloud:
    gateway:
      routes:
        - id: first-service
          uri: http://localhost:8081/
          predicates:
            - Path=/first-service/**
        - id: second-service
          uri: http://localhost:8082/
          predicates:
            - Path=/second-service/**

 

URL Test! ( http://localhost:8000/first-service/welcome )

Spring Cloud Gateway를 통해서 각 클라이언트 서비스가 호출되는 것을 확인할 수 있다!

 

이후 root를 필터를 통해서 고정하거나 제거를 처리해보겠습니다.