port 를 일정 범위안에서 랜덤하게 하면 discoveryService 에서 port를 다르게 인지합니다.
server:
port: ${random.int(10000,51000)} #0
spring:
application:
name: my-first-service
eureka:
client:
register-with-eureka: true
fetch-registry: true
service-url:
defaultZone: http://localhost:8761/eureka
instance:
instance-id: ${spring.application.name}:${spring.application.instance_id:${random.value}}
위처럼 서버의 Port 를 일정 범위안에서 랜덤하게 하면 아래와 같은 현상이 발생됩니다.
server:
port: 0
답변 1
7
안녕하세요, 이도원입니다.
말씀하신 것처럼, application.yml 파일에서 random.int를 사용하여 random port를 사용할 때, Eureka Server에 잘못된 포트 정보로 등록될 수 있습니다. 아래 이미지에서 첫번째는 port: ${random.int(10000,51000)}를 이용하여 기동했을 때 로그이고, 두번째는 port: 0으로 설정하고 기동했을 때의 로그입니다.
1. port: ${random.int(10000,51000)}

2. port: 0

2개의 로그를 확인해 보시면, 첫번째는 Eureka에 Register 하는 작업 도중에 Port를 업데이트 한 다음 등록을 완료하고, 두번째는 Port를 업데이트 한 다음 등록 작업을 시작하고 마무리하고 있습니다. 이러한 과정에서 random.int를 사용했을 때, 중간에 한번 더 업데이트 된 Port 정보가 Eureka에 등록되고(실제 Application에서는 Port가 변경되지 않음), Eureka 대시보드에서 잘못된 포트 정보를 가지고 표시하고 있습니다. 따라서 Random Port를 사용하실 때는 port: random.int 방식 보다는 port: 0으로 설정하시는게 좋을 것 같습니다. port: 0를 사용하셔야 하는 또하나의 이유로는, 중복 포트가 있을 경우, 해당 포트를 우회해서 다른 값을 설정하지만, port: random.int에서는 중복 값이 나오는 경우에는 애플리케이션을 그대로 기동하려고 하기 때문에, 포트 충돌로 인해 애플리케이션이 기동되지 않을수 있습니다.
추가로, 특정 범위를 지정하여 Random Port를 사용하실 려면, 아래와 같은 방법으로 처리해 보실 수 있습니다.
@Component를 갖는 클래스를 추가하시고 실행해 보시면,
@Component
public class CustomizationPort implements WebServerFactoryCustomizer<ConfigurableServletWebServerFactory> {
@Override
public void customize(ConfigurableServletWebServerFactory server) {
Random random = new Random();
var port = random.ints(10000, 51000)
.findFirst()
.getAsInt();
server.setPort(port);
}
}
다음과 같은 로그를 확인해 보실 수 있습니다.

위에서 설명 드렸던 바와 같이, 포트를 업데이트 한 다음, Eureka 서버에 등록을 마무리하고 있습니다. 위와 같은 작업 하셨을 경우에도 정상적으로 Load Balancing 작업이 되시는 것을 확인할 수 있습니다.


감사합니다.
kafka 업데이트 강의 듣고 시포요
0
79
1
강의 교안
0
64
1
마이크로서비스간 통신 시, 인증 처리
0
73
1
api gateway 에서 인증 처리
0
61
1
섹션 19 질문드립니다
0
47
1
강의 자료 업데이트
0
79
1
부하분산 강의 섹션
0
53
1
강의자료는 어디에서?
0
66
1
강의 자료는 어디서 다운 받을 수 있나요?
0
107
1
전체 사용자 조회시 오류
0
54
1
혹시 pk 외 별도의 id 를 부여한 이유가 있을까요 ??
0
106
2
학습 방향
0
92
2
카프카 커넥터 사용 목적 문의
0
83
2
kafka 강의
0
102
2
서비스 디스커버리 종류
0
84
2
강의 자료에 대해서 궁금해요
0
109
2
GlobalFilter, LoggingFilter가 동작하지 않습니다.
0
85
2
Kafka Source Connect 버전 에러
0
80
2
소스커넥터는 사용안한 거 맞죠?
0
78
2
강의자료 업데이트 문의
0
92
2
강의에서 BCryptPasswordEncoder 에 역할(5-2)
0
53
1
강의 업데이트 계획이 궁금합니다.
0
106
2
MSA 애플리케이션에 Spring Web과 Spring Data JPA를 사용하는 것이 바람직한지 궁금합니다. (MSA 설계와 관련된 질문입니다)
0
157
2
어떤 것이 업데이트 된 건가요?
0
157
2





