[Spring Cloud] Service Discover Server๋ก Netflix Eureka ์ด์ฉํ๊ธฐ
Spring Cloud Netflix
์คํ๋ง ํด๋ผ์ฐ๋ ๋ทํ๋ฆญ์ค๋ Spring Boot Application ์ ๋ํ ํตํฉ ํ๊ฒฝ ๊ตฌ์ฑ์ ์ง์ํ๋ Netflix์ OSS ์๋น์ค์ด๋ค.
Netflix๋ 2007๋ ์ฌ๊ฐํ DB์์์ผ๋ก 3์ผ๊ฐ ์๋น์ค ์ฅ์ ๋ฅผ ๊ฒผ์๋๋ฐ, ์ด์ ์ด์์ง๋ค๊ณผ ๊ธฐ์ ๋ฆฌ๋๋ค์ ์ ๋ขฐ์ฑ ๋๊ณ ์ํํ์ฅ์ด ๊ฐ๋ฅํ Cloud System์ผ๋ก ์ด์ ์ ํด์ผ ํจ์ ๋๊ผ์๋ค๊ณ ํ๋ค. ๊ทธ๋ฆฌ๊ณ ๊ฒฐ๊ตญ MSA๋ฅผ 7๋ ๋ง์ ์๋ฒฝํ๊ฒ ์ด์ ํ๊ฒ ๋์๋๋ฐ, ์ด ๋ ์์ ๊ฒฝํ์น๋ฅผ ๋ฐํ์ผ๋ก MSA ๊ธฐ์ ์ Spring์๊ฒ ์คํ์์ค๋ก ํ๊ฒ ๋์๋ค.
Netflix OSS ์ Spring Cloud Netflix
Netflix OSS ์๋ ๋ค์ํ ์๋น์ค๋ค์ด ์กด์ฌํ๋ค.
- Eureka : Discovery Server
- ๊ฐ๊ฐ์ ์๋น์ค ์ธ์คํด์ค๋ค์ด ๋์ ์ผ๋ก ํ์ฅ, ์ถ์ ๋๋๋ผ๋ ์ธ์คํด์ค์ ์ํ๋ฅผ ํ๋์ ์๋น์ค๋ก ๊ด๋ฆฌํ ์ ์๋ ์๋น์ค
- Ribbon : Client Side Load Balancer
- ๋ถํ ๋ถ์ฐ์ ์ํ ๋ชจ๋๋ฆฌ์ค์ L4 ์ค์์น์ ๊ฐ์ด ํธ๋ํฝ์ ๋ถ์ฐ์ํค๋ ๊ธฐ๋ฅ
- Zuul : API Gateway
- ๊ฐ๊ฐ์ ๋ง์ดํฌ๋ก์๋น์ค์ ์ข ๋จ์ ์ ์ฐ๊ฒฐํ๋ ๋ฆฌ๋ฒ์ค ํ๋ก์
- Hystrix : Circuit Breaker
- ํน์ ์๋น์ค๊ฐ ๊ณผ๋ถํ๊ฐ ๊ฑธ๋ ค ์๋น์ค ์ฅ์ ๋ฅผ ์ ํํ๋ ํน์ฑ์ ํด๊ฒฐํ๋ ค๋ ๊ธฐ๋ฅ
- EvCache
- Spectator
- Archaius
์ด๋ฐ ์๋น์ค๋ค์ด ๋ชจ๋ Spring Cloud ์์ ์ฌ์ฉ๋๋ ๊ฒ์ ์๋๋ค.
Spring ์ Spring Cloud ์ ์ ๋ง๋ ๋ช๋ช ์ ํ๋ค์ ๊ฐ์ ธ๋ค๊ฐ Spring Cloud์ ๋ง๊ฒ ์ฌ๊ตฌ์ฑํ์ฌ ์ ๊ณตํ๋ ์๋น์ค๋ค์ด ์กด์ฌํ๋ค.
์ต์ด์๋ ๋ชจ๋ ์๋น์ค๊ฐ Spring Cloud ์ ์ํด์ ๊ด๋ฆฌ๋์์ง๋ฉด ํ์ฌ๋ ๋ช๋ช ๊ธฐ์ ๋ค์ ์ฌ๊ตฌ์ฑ ํน์ ๋ฐ์ ์ํค๊ฑฐ๋ ๋
๋ฆฝ์ ์ธ ์๋น์ค๋ก ์งํ์์ผ ๊ธฐ์กด์ ์๋น์ค๋ค์ Maintenance ๋ชจ๋๋ก ๋ค์ด๊ฐ ๊ฒ๋ค์ด ์กด์ฌํ๋ค.
What is Maintenance Mode?
Placing a module in maintenance mode means that the Spring Cloud team will no longer be adding new features to the module. We will fix blocker bugs and security issues, and we will also consider and review small pull requests from the community.
๋ชจ๋์ ์ ์ง ๋ณด์ ๋ชจ๋๋ก ์ ํํ๋ฉด Spring Cloud ํ์ด ๋ ์ด์ ๋ชจ๋์ ์ ๊ธฐ๋ฅ์ ์ถ๊ฐํ์ง ์๊ฒ ๋ฉ๋๋ค. ์ฐจ๋จ ๋ฒ๊ทธ์ ๋ณด์ ๋ฌธ์ ๋ฅผ ํด๊ฒฐํ๊ณ , ์ปค๋ฎค๋ํฐ์ ์์ ๊บผ๋ด๊ธฐ ์์ฒญ๋ ๊ณ ๋ คํ๊ณ ๊ฒํ ํ ๊ฒ์ ๋๋ค.
Spring Cloud Netflix - Eureka
์์ ์๋ Maintenance Mode ๋ก ๋ค์ด๊ฐ ํ๋ก์ ํธ๋ฅผ ๋์ฒดํ ๋ช๋ช์ ํ๋ก์ ํธ๋ ์ด๋ฒ ์ฃผ์ ์์ ์ด์ผ๊ธฐํ์ง ์์ผ๋ ค ํ๋ค.
๋ง์ Netflix ์๋น์ค๊ฐ Maintenance ๋์์ง๋ง ๊ทธ ์ค์์๋ ๊ฐ์ฅ ์์ฃผ ์ ์ฉํ๋ Eureka์ ๋ํด์ ์์๋ณด์.
์ฐ์ Eureka ์ ์ญํ ์ ๋ํด์ ์๊ธฐ ์ํด์๋ Service Discover Pattern์ ๋ํด์ ์์์ผ ํ๋ค.
Service Discover ํจํด์ ๋ํด์ ์ ๋ชจ๋ฅธ๋ค๋ฉด MSA์ Service Mesh ํจํด์ ์ฐธ๊ณ ํ๋ฉด ๋์์ด ๋ ๋ฏ ํ๋ค.
Netflix-Eureka
๊ฐ๋จํ๊ฒ ๋งํ์๋ฉด Service Discovery๋ MSA ํต์ฌ ์์ ์ค ํ๋๋ค.
๊ฐ ํด๋ผ์ด์ธํธ์ ์ค์ ๋ฐ ์์น ์ ๋ณด (IP)๋ฅผ ์๋์ผ๋ก ๊ตฌ์ฑํ๋ค๋ฉด CI CD, ํน์ Scaling ์ ๋งค์ฐ ๋ง์ ์ ์ฝ์ฌํญ์ด ๋ฐ๋ฅธ๋ค.
ํ์ง๋ง Netlfix- Eureka๋ ์๋ฒ๋ฅผ ๊ตฌ์ฑ ๋ฐ ๋ฐฐํฌํ์ฌ ๊ฐ์ฉ์ฑ์ด ๋๋๋ก ํ ์ ์์ผ๋ฉฐ, ๊ฐ ์๋ฒ๋ ๋ฑ๋ก๋ ์๋น์ค์ ๋ํ ์ํ๋ฅผ ๋ค๋ฅธ ์๋ฒ๋ก ๋ณต์ ํ ์ ์๊ฒ ํ๋ ์ญํ ์ ํ๋ค.
์ด๋ฌํ Eureka์ ๊ฐ๋ ์๋ 2๊ฐ์ง ๊ตฌ์ฑ ์์๋ค์ด ์กด์ฌํ๋๋ฐ,
- Service Discovery
- ๊ฐ๊ฐ์ ์๋น์ค์ ์์น๊ฐ ๋ฑ๋ก๋ ์๋ฒ์์ ํน์ ์์
์ ์ํ ์๋ฒ์ ์์น๋ฅผ ํ์
ํ๋ ์์
์ ๋ปํ๋ค.
์ฐ๋ฆฌ๋ Service Discovery๋ฅผ ์ํด์ Spring Cloud Netflix - Eureka Server๋ฅผ ์ฌ์ฉํ๋ค.
- ๊ฐ๊ฐ์ ์๋น์ค์ ์์น๊ฐ ๋ฑ๋ก๋ ์๋ฒ์์ ํน์ ์์
์ ์ํ ์๋ฒ์ ์์น๋ฅผ ํ์
ํ๋ ์์
์ ๋ปํ๋ค.
- Service Registry
- ๊ฐ๊ฐ์ ์๋น์ค๊ฐ ์์ ์ ์์น(IP) ์ ๋ณด๋ฅผ ํน์ ์๋ฒ์ ๋ฑ๋ก Registry ํ๋ ์์
์ ๋งํ๋ค.
์ฐ๋ฆฌ๋ Service Registry๋ฅผ ์ํด์ Spring Cloud Netflix - Eureka Client๋ฅผ ์ฌ์ฉํ๋ค.
- ๊ฐ๊ฐ์ ์๋น์ค๊ฐ ์์ ์ ์์น(IP) ์ ๋ณด๋ฅผ ํน์ ์๋ฒ์ ๋ฑ๋ก Registry ํ๋ ์์
์ ๋งํ๋ค.
์ด๋ค์ ๊ฐ๊ฐ ์ด๋ค ์ผ์ ์ํํ๊ณ ์ด๋ค ์ผ์ ๊ฑฐ์น๋ฉด์ ๋์ํ ๊น?
Service Discover ๊ณผ์
Spring Cloud Eureka๋ ์๋์ ๊ฐ์ ์์๋ก ๋์ํ๊ฒ ๋๋ค.
- Service Registry ๊ธฐ๋ฅ์ ํ Eureka Server ๊ฐ ์ต์ด์ ๊ธฐ๋๋๋ค.
- Service Registry ์๋ฒ์ธ Eureka Server ์ ๋ฑ๋ก๋ ์๋น์ค๋ค์ด ๊ธฐ๋๋๋ค. ์ฌ๊ธฐ์ ๋ฑ๋ก๋ ์๋น์ค๋ Eureka Client ๋ผ๊ณ ํ๋ค.
- Eureka ์๋ฒ๋ ์์ ์๊ฒ ๋ฑ๋ก๋ Eureka Client ์๊ฒ 30์ด๋ง๋ค Ping์ ๋ณด๋ด๋ฉฐ Health Checking์ ์ํํ๋ค.
- ๋ง์ฝ 30์ด๋ง๋ค ๋ณด๋ด๋ Heart Heat๊ฐ ์ผ์ ํ์ ์ด์์ผ๋ก ๋์๋์ง ์์ผ๋ฉด Eureka Server๋ ํด๋น Client๋ฅผ ์ญ์ ํ๋ค.
Eureka๋ ๋จ์ง ์๋น์ค์ ์์น๋ง์ ํํํ๋ ์ญํ ๋ก ๋ณดํต Spring Cloud Gateway๋ Netflix Zuul ๊ณผ ๊ฐ์ Gateway ์๋น์ค๋ Ribbon ๊ณผ ๊ฐ์ ํด๋ผ์ด์ธํธ ์ฌ์ด๋ ๋ก๋๋ฐธ๋ฐ์์ ํจ๊ป ๋์ํ๋ค.
์ค์ตํ๊ธฐ
์ด์ ๋์ถฉ ๊ฐ๋ ์ ๋ํ ๋ถ๋ถ์ ํ์ ํ์ผ๋ ์ค์ Spring Boot๋ฅผ ์ด์ฉํด์ Eureka ์๋ฒ์ ํด๋ผ์ด์ธํธ๋ฅผ ์ด์ฉํ ๊ตฌ์ฑ์ ํด๋ณด์.
์ฐ๋ฆฌ๋ 2๊ฐ์ ์๋น์ค์ 1๊ฐ์ Service Discovery ์๋ฒ๋ฅผ ๊ฐ์ฉํ ๊ฒ์ด๋ค.
- Service Discovery Server
- Discovery Application
Spring Cloud Eureka-Server
- Discovery Application
- Microservices
- UserService
Spring Cloud Eureka-Client
- OrderService
Spring Cloud Eureka-Client
- UserService
Spring Cloud Eureka Server
- ํ๋ก์ ํธ ์์ฑ
- ์์กด์ฑ ์ถ๊ฐ
- application.yml ์์ฑ
- DiscoveryApplication ์
@EnableEurekaServer
๋ฑ๋ก - Eureka Dashboard
๊ธฐ๋ณธ์ ์ผ๋ก ์ค์ต IDE๋ IntelliJ๋ฅผ ์ด์ฉํ ๊ฒ์ด๋ค.
๋ง์ฝ ๋ณธ์ธ์ด IntelliJ ๋ผ์ด์ผ์ค๊ฐ ์๊ณ ํ์์ด๋ค๋ฉด 1๋ ๋ฌด๋ฃ ์ด์ฉ ๋ผ์ด์ผ์ค๊ฐ ์กด์ฌํ๋ ์ด์ฉํ๋ ๊ฒ๋ ๋์์ง ์๋ค.
์ค์ต ํ๋ก์ ํธ ์์ฑ
์ฐ์ ์ค์ต์ ์ํ ๋๋ ํ ๋ฆฌ๋ฅผ ์์ฑํ์.
๋๋ my-msa ๋ผ๋ ๋๋ ํ ๋ฆฌ๋ฅผ ์์ฑํ๋ค.
๊ทธ๋ฆฌ๊ณ ํด๋น ๋๋ ํ ๋ฆฌ ์๋์ Discovery-Server ๋ฅผ ์์ฑํ์.
์์กด์ฑ ์ถ๊ฐ
ํ์ํ ์์กด์ฑ์ Spring Cloud Eureka Server ์ด๋ค.
ext {
set('springCloudVersion', "2020.0.2")
}
dependencies {
implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-server'
}
dependencyManagement {
imports {
mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
}
}
์ฌ๊ธฐ์ Spring Boot์ ๋ฒ์ ๊ณผ Spring Cloud ์ ๋ฒ์ ์ ๋งค์ฐ ์ค์ํ๋ค. ๊ฐ๊ฐ ํธํ์ด ๋๋ ๋ฒ์ ์ด ๋ฐ๋ก ์์ผ๋ ์ถฉ๋ถํ ์กฐ์ฌํด๋ณด๋๋ก ํ์. ์ผ๋จ ํ์ฌ 2021๋ 4์ ๊ธฐ์ค์ผ๋ก๋ Spring Boot 2.4 ๋ ๋ฒ์ ๊ณผ Spring Cloud 2020 ๋ฒ์ ์ด ๊ถ์ฅ๋๊ณ ์๋ค.
application.yml ์์ฑ
Springboot ํ๋ก์ ํธ๋ฅผ ์์ฑํ๋ฉด ๊ธฐ๋ณธ์ ์ผ๋ก ์ค์ ์ ์ํ ํ์ผ๋ก application.properties
ํ์ผ์ด ์์ฑ๋๋๋ฐ, ํด๋น ํ๋กํผํฐ ํ์ผ์ ์ค๋ณต๋๋ ์ฝ๋๊ฐ ๋ง์ด ๋์ฌ ์ ์์ผ๋ฏ๋ก aaplication.yml
ํ์ผ๋ก ๋์ฒดํ์ฌ ์์ฑํ๋ค.
server:
port: 8761 # 1๋ฒ
spring:
application:
name: discovery-service # 2๋ฒ
eureka:
client:
register-with-eureka: false # 3๋ฒ
fetch-registry: false # 4๋ฒ
application.yml ํ์ผ์ด ํด๋น ํ๋ก์ ํธ์์ ๊ฐ์ฅ ๊ฐ์ฅ ๊ฐ์ฅ ์ค์ํ ํ์ผ์ด๋ค.
- server.port : ํด๋น ์ ๋ ์นด ์๋ฒ๊ฐ ๋์๋๋ ์๋ฒ์ ํฌํธ๋ฅผ ์ง์ ํ๋ค. ๋ณดํต 8761 ํฌํธ๋ฅผ ๋ง์ด ์ฌ์ฉํ๋ค.
- spring.application.name : Application ์ด๋ฆ์ ์ง์ ํ ์ ์๋๋ฐ, ์์ผ๋ก ๋ชจ๋ ์๋น์ค๋ฅผ application.name ์ผ๋ก ์๋ณํ๋ค.
- eureka.client.register-with-eureka : ํด๋น ์๋ฒ๋ฅผ ํด๋ผ์ด์ธํธ๋ก ๋์์ํค๊ฒ ๋๋ ์ค์ ์ false ๋ก ์ค์ ํด์ผ ํ๋ค.
- eureka.client.fetch-registry : ์์ ๋์ผํ false๋ก ์ง์ ํด์ผ ํ๋๋ฐ, ๊ทธ๋ ์ง ์์ผ๋ฉด ์์ ์ ๋์ค์ปค๋ฒ๋ฆฌ์ ๋ฑ๋กํ๊ฒ ๋๋ค.
DiscoveryApplication ์ @EnableEurekaServer
๋ฑ๋ก
ํ๋ก์ ํธ์ Application์ด ๋์๊ฐ๋ ๋ฃจํธ ๋๋ ํ ๋ฆฌ๋ก ๊ฐ์ DiscoveryApplication.java๋ฅผ ํด๋ฆญํ๋ค.
๊ทธ๋ผ @SpringBootApplication
์ด๋ผ๋ ์ด๋
ธํ
์ด์
์ด ๋ถ์ด์๋๋ฐ, ํด๋น ์ด๋
ธํ
์ด์
์๋์ @EnableEurekaServer
์ด๋
ธํ
์ด์
์ ์ถ๊ฐํด์ค๋ค.
๊ทธ๋ผ ํด๋น ์๋ฒ๋ EurekaServer ๋ก ๋์ํ๊ฒ ๋๋ ๊ฒ์ด๋ค.
@SpringBootApplication
@EnableEurekaServer
public class EurekaApplication {
public static void main(String[] args) {
SpringApplication.run(EurekaApplication.class, args);
}
}
๊ทธ๋ฆฌ๊ณ App์ ์คํ์์ผ๋ณด์.
๊ทธ๋ผ ์ ์์ ์ผ๋ก ์ ์คํ์ด ๋๋ ๊ฒ์ ๋ณผ ์ ์๋ค.
๊ทธ๋ฆฌ๊ณ localhost:8761 ๋ก ์ ์ํ๋ฉด Eureka Dashboard๋ฅผ ํ์ธํ ์ ์๋๋ฐ ์์ผ๋ก ์์ฃผ ๋ณด๊ฒ๋ ๋์ฌ๋ณด๋์ด๋ค.
Spring Cloud Eureka Client
- ํ๋ก์ ํธ ์์ฑ
- ์์กด์ฑ ์ถ๊ฐ
- application.yml ์์ฑ
- UserApplication์ OrderService ์
@EnableDiscoveryClient
์ด๋ ธํ ์ด์ ์ถ๊ฐ - ๊ฐ๊ฐ ์๋ฒ์ Controller ์์ฑ
์ฐ๋ฆฌ๋ ๋ง์ดํฌ๋ก์๋น์ค๋ก 2๊ฐ์ ๋ง์ดํฌ๋ก์๋น์ค๋ฅผ ๊ตฌ์ฑํ๋ค๊ณ ํ๋ค.
- User ์๋น์ค
user-service
- Order ์๋น์ค
order-service
ํ๋ก์ ํธ 2๊ฐ๋ฅผ ๊ฐ๊ฐ ์์ฑํ๊ณ ์ด๋ฆ์ ์์ ๊ฐ์ด ํด๋ณด์.
ํ๋ก์ ํธ ์์ฑ
ํ๋ก์ ํธ๋ฅผ ๊ฐ๊ฐ user-service
์ order-service
๋ก ๊ฐ๊ฐ ์์ฑํ์
์์กด์ฑ ์ถ๊ฐ
ํ๋ก์ ํธ๋ฅผ ๊ฐ๊ฐ user-service
์ order-service
๋ก ๊ฐ๊ฐ ์์ฑํ๊ณ ๋ค์ ์ด๋
ธํ
์ด์
์ ์ถ๊ฐํด์ฃผ์!
- Lombok
- Spring Web
- Eureka Discovery Client
ํด๋น ์๋ฒ๋ Springboot ์ ์ผ๋ฐ์ ์ธ ์๋ฒ๋ก์ ๋์ํ ๊ฒ์ด๊ธฐ ๋๋ฌธ์ Spring Web ์์กด์ฑ๊ณผ Lombok ์์กด์ฑ์ ์ถ๊ฐ๋ก ๋ฐ์์ผ ํ๋ค.
plugins {
id 'org.springframework.boot' version '2.4.5'
id 'io.spring.dependency-management' version '1.0.11.RELEASE'
id 'java'
}
group = 'com.example'
version = '0.0.1-SNAPSHOT'
sourceCompatibility = '11'
configurations {
compileOnly {
extendsFrom annotationProcessor
}
}
repositories {
mavenCentral()
}
ext {
set('springCloudVersion', "2020.0.2")
}
dependencies {
implementation 'org.springframework.boot:spring-boot-starter-web'
implementation 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'
compileOnly 'org.projectlombok:lombok'
annotationProcessor 'org.projectlombok:lombok'
testImplementation 'org.springframework.boot:spring-boot-starter-test'
}
dependencyManagement {
imports {
mavenBom "org.springframework.cloud:spring-cloud-dependencies:${springCloudVersion}"
}
}
test {
useJUnitPlatform()
}
application.yml ์์ฑ
UserService
server:
port: 64412
spring:
application:
name: user-service
eureka:
instance:
instance-id: user-microservice-instance
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://localhost:8761/eureka
OrderService
server:
port: 54412
spring:
application:
name: order-service
eureka:
instance:
instance-id: order-microservice-instance
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://localhost:8761/eureka
๋ญ๊ฐ ๋ง์๋ณด์ธ๋ค. ํ๋์ฉ ์์๋ณด์.
- server.port : ์๋ฒ์ ํฌํธ ๋ฒํธ, ์์ ๋์ผํ๋ค
- spring.application.name : ์ ํ๋ฆฌ์ผ์ด์ ์๋ฒ์ ์ด๋ฆ , ์์ ๋์ผํ๋ค
- eureka.instance.instance-id ์ ๋ ์นด๊ฐ ์ธ์ํ instance id ์ธ๋ฐ ๋์ฌ๋ณด๋์์ ์๋ณํ๋ ์ฉ๋๋ก ์ฌ์ฉ๋๋ค.
- eureka.client.register-with-eureka & fetch-registry ์ด๋ฒ์๋ ํด๋น ์๋น์ค๊ฐ ํด๋ผ์ด์ธํธ๋ก ์ธ์๋์ด์ผ ํ๋ฏ๋ก true๋ก ํด์ฃผ์
- eureka.client.service-url.defaultZone : eureka server ๊ฐ ์์นํ๊ณ ์๋ ๊ธฐ๋ณธ ์ฃผ์๋ฅผ ์ ์ด์ค ์ ์๋ค.
defaultZone ๊ฐ์ ๊ฒฝ์ฐ๋ ๊ผญ Camel Case ๋ก ์ ์ด์ผ ํ๋ค๊ณ Spring Cloud Eureka์ ๋์์๋ค.
The defaultZone property is case sensitive and requires camel case because the serviceUrl property is a Map<String, String>. Therefore, the defaultZone property does not follow the normal Spring Boot snake-case convention of default-zone.
Application์ @EnableDiscoveryClient
์ด๋
ธํ
์ด์
์ถ๊ฐ & Controller ์ถ๊ฐ
ํด๋น ์๋น์ค๊ฐ Eureka Client ์์ ์๋ ค์ฃผ๋ ์ด๋ ธํ ์ด์ ๊ณผ ๋๋ถ์ด ๊ฐ๊ฐ์ ์๋น์ค๋ฅผ ์๋ณํ๊ธฐ ์ํด์ ์ปจํธ๋กค๋ฌ๋ฅผ ์ถ๊ฐํด๋ณด์.
@SpringBootApplication
@EnableDiscoveryClient
@RestController
public class UserServiceApplication {
public static void main(String[] args) {
SpringApplication.run(UserServiceApplication.class, args);
}
@GetMapping("/info")
public String info(@Value("${}") String port) {
return "User ์๋น์ค์ ๊ธฐ๋ณธ ๋์ Port: {" + port + "}";
}
}
@SpringBootApplication
@EnableDiscoveryClient
@RestController
public class OrderServiceApplication {
public static void main(String[] args) {
SpringApplication.run(UserServiceApplication.class, args);
}
@GetMapping("/info")
public String info(@Value("${server.port}") String port) {
return "Order ์๋น์ค์ ๊ธฐ๋ณธ ๋์ Port: {" + port + "}";
}
}
๊ทธ๋ฆฌ๊ณ ๋ค์ ์ ๋ ์นด ๋์ฌ๋ณด๋๋ก ๊ฐ๋ฉด ์์ ๋ฑ๋กํ๋ 2๊ฐ์ ์๋น์ค๊ฐ ์ฌ๋ผ์จ ๊ฒ์ ํ์ธํ ์ ์๋ค.
๊ฐ๊ฐ URL์ ๋ค์ด๊ฐ์ /info ์ฃผ์๋ก ํฅํ๋ค๋ฉด ์ ๋์ํ๋ ๊ฒ์ ๋ณผ ์ ์๋ค.
์ด๋ ๊ฒ ์ค๋์ ์์ฃผ์์ฃผ ๊ธฐ๋ณธ์ ์ธ Spring Cloud Eureka์ ๋ํด์ ์์๋ณด์๋ค.
Spring Cloud Eureka๋ Default ์ค์ ์ด ์์ฃผ ๊ธฐ๊ฐ๋งํ์ ๋ฐ๋ก ์ค์ ์ ํ์ง ์๋๋ผ๋ ์ฌ์ฉํ ์ ์๋ ์์ค์ด๋ผ๊ณ ํ๋ค.
ํ์ง๋ง ์ด์ฉ ์ ์๋ ๋ช๋ช ์ํฉ์ด ์กด์ฌํ๋๋ฐ, ๊ทธ๋ฐ ์ํฉ์์ ๋์๋ ์ ์๋ ๋ช๊ฐ์ง Eureka ๊ณ ๊ธ ์ค์ ๊ธฐ๋ฒ๋ค์ ๋ค์์๊ฐ์ ์์๋ณด๋๋กํ์.