inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Spring Cloud로 개발하는 마이크로서비스 애플리케이션(MSA)

Spring Cloud Gateway + Eureka 연동

Gateway와 Discovery를 사용한 무중단 서비스 방법

해결된 질문

565

Jin J

작성한 질문수 3

1

안녕하세요 선생님? 강의 정말 잘보고있습니다. 감사합니다. 다름이 아니라 강의 내용처럼 따라서 잘구성해보았습니다. 잘돌아갑니다. 그런데 해결하고 싶은게 있습니다.

동일 서비스 중 하나가 중단됬을때 Gateway가 LB방식이라 중단된줄 모르고 중단된 서비스로 요청이 들어갑니다. 그러다보니 Connection 오류가 납니다. 대략 30초에서 1분 이후부터는 살아있는 서비스로만 요청이가서 잘 동작합니다. 만약 운영중이라면 30초에서 1분동안은 서비스가 불안할텐데 어떡하면 해결할 수 있을까요?

시스템 구성은 다음과 같습니다.

GW <-> Discovery <-> 동일서비스 #3개(만약 #2번이 다운됬을때 #2번 서비스가 호출되어 서비스가 됬다 안됬다 하는 현상발생)

좋은 방법이나 예제가 있으면 감사하겠습니다.

 

msa Kafka spring-boot architecture JPA spring-cloud

답변 1

0

Dowon Lee

안녕하세요, 이도원입니다.

Eureka Server에서 클라이언트(인스턴스)로부터의 연결이 끊겼다는 것을 인식할 때까지 최대 30초의 시간이 소요될 수 있습니다. 이건은 Eureka Server의 기본 설정값이기 때문에 이 설정을 변경하실 수 있습니다.

eureka.client.registry-fetch-interval-seconds: 30 (30초, Eureka Server에서 레지스트리 정보를 가져오는 빈도)

eureka.instance.lease-renewal-interval-in-seconds: 30 (30초, Eureka Client가 활성 상태임을 알려주기 위해 Eureka Server에게 Heartbeats를 보내야 하는 빈도, 지정된 기간 동안 Heartbeats가 수신되지 않으면 인스턴스에 대한 Traffic을 허용하지 않고 제거)

https://cloud.spring.io/spring-cloud-static/Dalston.SR5/multi/multi__appendix_compendium_of_configuration_properties.html

감사합니다.

rabbitmq에 configservice 연결에 대해 질문있습니다.

0

12

1

kafka 업데이트 강의 듣고 시포요

0

118

2

강의 교안

0

107

2

마이크로서비스간 통신 시, 인증 처리

0

118

2

api gateway 에서 인증 처리

0

76

1

섹션 19 질문드립니다

0

87

2

강의 자료 업데이트

0

105

2

부하분산 강의 섹션

0

67

1

강의자료는 어디에서?

0

99

2

강의 자료는 어디서 다운 받을 수 있나요?

0

133

2

전체 사용자 조회시 오류

0

66

1

혹시 pk 외 별도의 id 를 부여한 이유가 있을까요 ??

0

122

2

학습 방향

0

107

2

카프카 커넥터 사용 목적 문의

0

93

2

kafka 강의

0

119

2

서비스 디스커버리 종류

0

91

2

강의 자료에 대해서 궁금해요

0

126

2

GlobalFilter, LoggingFilter가 동작하지 않습니다.

0

97

2

Kafka Source Connect 버전 에러

0

98

2

소스커넥터는 사용안한 거 맞죠?

0

86

2

강의자료 업데이트 문의

0

101

2

강의에서 BCryptPasswordEncoder 에 역할(5-2)

0

64

1

강의 업데이트 계획이 궁금합니다.

0

122

2

MSA 애플리케이션에 Spring Web과 Spring Data JPA를 사용하는 것이 바람직한지 궁금합니다. (MSA 설계와 관련된 질문입니다)

0

168

2