Eureka

๋กœ์ปฌ์˜ ํ™˜๊ฒฝ์—์„œ๋Š” ๋กœ๋“œ๋ฐธ๋Ÿฐ์„œ๋ฅผ ํ†ตํ•ด ์„œ๋น„์Šค์˜ ๋ฐœ๊ฒฌ์„ ์ˆ˜ํ–‰ํ•ด์™”๋Š”๋ฐ ๋งคํ•‘ ๊ทœ์น™์„ ๋งค๋ฒˆ ์ˆ˜๋™์œผ๋กœ ์ง€์ •ํ•˜๋Š” ๊ฒƒ์€ Cloud Native architecture์— ๋“ค์–ด์„œ์„œ ๋ถ€์ ํ•ฉํ•˜๊ธฐ ๋•Œ๋ฌธ์— ์ž์‹ ์˜ ์„œ๋น„์Šค๋ฅผ ๋™์ ์œผ๋กœ ๋“ฑ๋กํ•˜๊ณ  ์Šค์Šค๋กœ ๋ผ์ดํ”„ ์‚ฌ์ดํด์„ ๊ด€๋ฆฌํ•  ์ˆ˜ ์žˆ๋„๋ก ๊ด€๋ฆฌ ํ•  ์ˆ˜ ์žˆ๊ฒŒ ํ•ด์ฃผ๋Š” ๊ธฐ๋Šฅ์ด ํ•„์š”ํ•ด์กŒ๊ณ  ์ด๋Ÿฌํ•œ ์ž‘์—…์„ ์œ„ํ•ด ์„œ๋น„์Šค ๋””์Šค์ปค๋ฒ„๋ฆฌ ๋งค์ปค๋‹ˆ์ฆ˜๊ฐ€ ์ƒ๊ฒจ๋‚ฌ๋‹ค.

์„œ๋น„์Šค ๋””์Šค์ปค๋ฒ„๋ฆฌ ๋งคํ„ฐ๋‹ˆ์ฆ˜์€ ๋‹ค์Œ๊ณผ ๊ฐ™์€ ํŠน์ง•๋ฅผ ๊ฐ–๋Š”๋‹ค.

  • ์„œ๋น„์Šค ๋™์  ๋“ฑ๋ก ๋ฐ ์ •๋ณด ๊ณต์œ 

    ์„œ๋น„์Šค๊ฐ€ ์‹œ์ž‘๋ ๋•Œ ์œ„์น˜, ํฌํŠธ๋“ฑ ์ •๋ณด๋ฅผ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์— ๋™์ผํ•œ ์„œ๋น„์Šคid๋กœ ๋“ฑ๋ก ํ•œ๋‹ค. ๋“ฑ๋ก๋œ ์„œ๋น„์Šค๋Š” ํด๋Ÿฌ์Šคํ„ฐ์— ์žˆ๋Š” ๋‹ค๋ฅธ ๋…ธ๋“œ๋“ค์—๊ฒŒ ์ „ํŒŒํ•œ๋‹ค.

  • ์„œ๋น„์Šค ๋™์  ๋ฐœ๊ฒฌ

    ์ •์ ์œผ๋กœ ์„œ๋น„์Šค๋ฅผ ์„ค์ •ํ•˜๊ณ  ๊ด€๋ฆฌํ•˜๋Š”๊ฒƒ์ด ์•„๋‹Œ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ๋ฅผ ํ†ตํ•ด ๋ฐ”๋กœ ๋ฐ”๋กœ ์‚ฌ์šฉ๊ฐ€๋Šฅํ•œ url์„ ๋ฐœ๊ฒฌํ•˜๊ณ  ๋งค๋ฒˆ ์ •๋ณด๋ฅผ ์—…๋ฐ์ดํŠธ ํ•œ๋‹ค.

  • ์ƒํƒœ ๋ชจ๋‹ˆํ„ฐ๋ง : ๊ฐ ์„œ๋น„์Šค(์ธ์Šคํ„ด์Šค)๋“ค์€ ์ž์‹ ์˜ ์ƒํƒœ๋ฅผ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์—๊ฒŒ ์•Œ๋ฆฐ๋‹ค.

๊ตฌ์„ฑ

  1. Eureka Server : Eureka client์— ํ•ด๋‹นํ•˜๋Š” ๋งˆ์ดํฌ๋กœ์„œ๋น„์Šค๋“ค์˜ ์ƒํƒœ์ •๋ณด๊ฐ€ ๋“ฑ๋ก๋˜์–ด ์žˆ๋Š” ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ๋ฅผ ๊ฐ–๋Š”๋‹ค.

  2. Eureka Client : ์„œ๋น„์Šค๊ฐ€ ์‹œ์ž‘๋  ๋•Œ Server์— ์ž์‹ ์˜ ์ •๋ณด๋ฅผ ๋“ฑ๋กํ•ด์„œ 30์ดˆ๋งˆ๋‹ค ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์— ping์„ ๋ณด๋‚ด ๊ฐ€์šฉ์ƒํƒœ๋ฅผ ์•Œ๋ฆฌ๊ณ  ์ผ์ • ์ด์ƒ ๋ฐ›์ง€ ๋ชปํ•˜๋ฉด Server๋Š” ์„œ๋น„์Šค๋ฅผ ๋ ˆ์ง€์ŠคํŠธ๋ฆฌ์—์„œ ์ œ์™ธ์‹œํ‚จ๋‹ค.

๊ฐ€์šฉ์ƒํƒœ์˜ ์„œ๋น„์Šค ๋ชฉ๋ก์„ ํ™•์ธํ•  ๊ฒฝ์šฐ ์„œ๋น„์Šค์˜ ์ด๋ฆ„์„ ๊ธฐ์ค€์œผ๋กœ ํƒ์ƒ‰ํ•˜๋ฉฐ ๋กœ๋“œ๋ฐธ๋Ÿฐ์‹ฑ์„ ์œ„ํ•ด Ribbon์„ ๋‚ด๋ถ€์ ์œผ๋กœ ์‚ฌ์šฉํ•œ๋‹ค.

@EnableEurekaServer

ํ•ด๋‹น ์„œ๋น„์Šค๋ฅผ Eureka ์„œ๋ฒ„๋กœ ์ง€์ •ํ•˜๊ธฐ ์œ„ํ•ด์„œ ์„œ๋น„์Šค ์ง„์ž…์ ์ด ๋˜๋Š” ํด๋ž˜์Šค์— ํ•ด๋‹น ์–ด๋…ธํ…Œ์ด์…˜์„ ๋ถ™์—ฌ์ฃผ์–ด์•ผ ํ•œ๋‹ค.

๊ธฐ๋ณธ ํ™˜๊ฒฝ ์„ค์ • (application.yml)

  1. eureka.client.register-with-eureka

  2. eureka.client.fetch-registry

๊ธฐ๋ณธ๊ฐ’์€ true๋กœ ์ž๊ธฐ์ž์‹ ์˜ ์ •๋ณด๋ฅผ client๋กœ ๋“ฑ๋กํ•˜๊ณ  ์ƒํƒœ๋ฅผ ํŒจ์นญํ•˜๋Š” ์„ค์ •์œผ๋กœ ๋‹ค๋ฅธ ์„œ๋น„์Šค๋“ค๊ณผ ํ†ต์‹ ์„ ํ•˜๊ธฐ ์œ„ํ•ด์„œ๋Š” true์ด์–ด์•ผ ํ•œ๋‹ค.

  1. eureka.client.service-url.defaultZone : ์œ ๋ ˆ์นด ์„œ๋ฒ„์˜ ์œ„์น˜๋ฅผ ๋ช…์‹œํ•ด์ฃผ์–ด์•ผ ํ•œ๋‹ค.

  2. eureka.instance.instance-id : instance id๋ฅผ ์„ค์ •

    ex) ${spring.cloud.client.hostname}:${spring.application.instance_id:${random.value}}

์ถ”๊ฐ€) IntelliJ์—์„œ ํ•˜๋‚˜์˜ ์„œ๋น„์Šค๋ฅผ ์‹คํ–‰์‹œํ‚ฌ๋•Œ ํฌํŠธ์˜ต์…˜์„ ๋‹ค๋ฅด๊ฒŒ ์ฃผ๋Š” ๋ฐฉ๋ฒ•

IntelliJ์—์„œ ์„ค์ •

  1. application.yml์—์„œ server.port ์ง€์ •

    • server.port๋ฅผ 0์œผ๋กœ ์‹คํ–‰์‹œํ‚ค๋ฉด random port๋กœ port๊ฐ€ ์ถฉ๋Œ๋‚˜์ง€ ์•Š๋„๋ก ์•Œ์•„์„œ ์ง€์ •ํ•ด์„œ ์‹คํ–‰๋œ๋‹ค.

      ํ•˜์ง€๋งŒ ์ด ๊ฒฝ์šฐ์—๋Š” ์„œ๋น„์Šคid๊ฐ€ ๋™์ผํ•˜๊ฒŒ ๋˜๋ฉด ํ•˜๋‚˜์˜ ์ธ์Šคํ„ด์Šค๊ฐ€ ๋“ฑ๋ก๋œ๊ฒƒ์œผ๋กœ ํ™•์ธ์ด ๋˜๊ธฐ ๋•Œ๋ฌธ์— eureka.instance.instance-id๋ฅผ ํ†ตํ•ด ์ธ์Šคํ„ด์Šค ์ด๋ฆ„์„ ๋ฐ”๊พธ์–ด ์ฃผ์–ด์•ผ ํ•œ๋‹ค.

  2. run configuration์—์„œ Environments -> JVM option์œผ๋กœ -Dserver.port='9001' ์ง€์ • Terminal์—์„œ ์„ค์ •

  3. java์‹คํ–‰ ์˜ต์…˜์œผ๋กœ ์„ค์ • mvn compile package๋ฅผ ํ†ตํ•ด jarํŒจํ‚ค์ง• ํ›„ java -jar -Dserver.port=9001 ํŒŒ์ผ๊ฒฝ๋กœ/jar์ด๋ฆ„.jar๋กœ jarํŒŒ์ผ ์‹คํ–‰

  4. mvn run ๋ช…๋ น์–ด์— ์˜ต์…˜์œผ๋กœ ์„ค์ • ํ›„ ์‹คํ–‰

    mvn spring-boot:run -Dspring-boot.run.jvmArguments='-Dserver.port=9003'

depenecy ์ถ”๊ฐ€

Spring boot ๋ฒ„์ „์„ ์„ค์ •ํ•˜๋ฉด ๊ทธ์— ๋งž๋Š” spring cloud๋ฒ„์ „์ด ์•Œ์•„์„œ ์„ค์ •๋œ๋‹ค.

Eureka Server

  • maven

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
</dependency>
  • gradle

dependencies {
  compile 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-server'
}

Eureka Client

  • maven

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
  • gradle

dependencies {
  compile 'org.springframework.cloud:spring-cloud-starter-netflix-eureka-client'
}

Last updated