반응형
Spring Cloud Eureka 란?
Spring Cloud Eureka는 서비스 디스커버리 패턴을 구현하는 데 사용되는 오픈소스 도구입니다.
서비스 디스커버리는 마이크로서비스 간의 통신을 지원하고, 서비스 인스턴스의 위치 정보를 실시간으로 전달합니다.
Eureka 서버는 서비스가 서로를 찾을 수 있도록, 등록 및 검색 기능을 제공합니다.
서비스 디스커버리 패턴이란?
분산 애플리케이션에 포함된 여러 서비스 간의 통신이나 상호작용을 자동화하기 위한 아키텍처 패턴입니다.
마이크로서비스 아키텍처에서 여러 컴포넌트들은 위치 정보, 상태 변경, 내부 설정 등을 수시로 변경하기 때문에 이러한 변경사항을 신속하게 감지하여 처리할 필요가 있습니다.
- 서비스 디스커버리 서버 : 서비스의 인스턴스들이 위치 정보를 등록하고 조회할 수 있는 중앙 서버입니다.
- 서비스 인스턴스 : 서비스 디슨커버리 패턴에 참여하는 개별 서비스 입니다.
왜 사용할까?
마이크로서비스 아키텍처는 인스턴스의 IP 주소와 포트가 지속적으로 변경될 수 있습니다.
클라이언트가 서비스를 빠르게 찾을 수 있도록 한 곳에서 정보를 관리하려면 서비스 디스커버리가 필요합니다.
클라이언트와 서버가 동일한 Eureka 서버에 등록되면, 클라이언트는 서비스 이름을 사용하여 필요한 서버의 IP 주소와 포트를 자동으로 얻을 수 있습니다.
로드 밸런싱 및 분산 시스템을 지원하고, 복잡한 마이크로서비스 구조의 앱을 구축할 때 유용합니다.
기능!
서비스 디스커버리
서비스 인스턴스의 등록 및 검색 기능을 제공합니다.
클라이언트 사이드 로드 밸런싱
클라이언트가 자동으로 가용한 서비스 인스턴스 중 하나를 선택합니다.
헬스 체크
인스턴스의 상태를 확인하여 가용한 서비스 목록을 유지합니다.
Spring Boot 에서 Eureka 서버, 클라이언트 구축하기
Eureka Server 설정
build.gradle
ext {
set('springCloudVersion', "2021.0.4")
}
dependencies {
implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-server'
...
}
dependencyManagement {
imports {
mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
}
}
application
@EnableEurekaServer
@SpringBootApplication
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class, args);
}
}
application.yml
server:
port: 8761
eureka:
client:
registerWithEureka: false
fetchRegistry: false
server:
waitTimeInMsWhenSyncEmpty: 5
serverUrl:
defaultZone: http://127.0.0.1:8671
이걸로 Eureka Server 설정은 끝이다.
이렇게까지 설정하고 localhost:8761 에 들어가면
이렇게 뜨면 성공이다!
Eureka Client 설정
build.gradle
ext {
set('springCloudVersion', "2021.0.4")
}
dependencies {
implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'
}
dependencyManagement {
imports {
mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
}
}
application
@EnableDiscoveryClient
@SpringBootApplication
public class ApiGatewayApplication {
public static void main(String[] args) {
SpringApplication.run(ApiGatewayApplication.class, args);
}
}
application.yml
spring:
application:
name: AUTH-SERVICE // 서비스 이름
eureka:
instance:
preferIpAddress: true
client:
registerWithEureka: true
fetchRegistry: true
serviceUrl:
defaultZone: http://127.0.0.1:8761/eureka/
server:
port: 8083 // 서비스 포트
이렇게 하고 실행하고 다시 localhost:8761에 들어가면
이렇게 AUTH-SERVICE가 등록된것을 볼 수 있다!