Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

cannot register to eureka server with random port and AOT #4235

Closed
vladgon opened this issue Dec 23, 2023 · 8 comments
Closed

cannot register to eureka server with random port and AOT #4235

vladgon opened this issue Dec 23, 2023 · 8 comments
Assignees
Milestone

Comments

@vladgon
Copy link

vladgon commented Dec 23, 2023

mavenBom 'org.springframework.cloud:spring-cloud-dependencies:2023.0.0

According to

https://github.com/spring-cloud/spring-cloud-release/wiki/AOT-transformations-and-native-image-support and other documentation spring.cloud.refresh.enabled should be false when AOT compiling.

Application works fine when spring.cloud.refresh.enabled is true, but fails to register (registers with the port 0 ) when refresh is disabled

Server application.yaml

spring:
  application:
    name: demo-eureka-server

server:
  port: 8761

eureka:
  client:
    register-with-eureka: false
    fetch-registry: true

  dashboard:
    path: /dashboard

Client application.yaml

server:
  port: 0

spring:
  application:
    name: GreetingServer
  cloud:
    refresh:
      enabled: false
eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka
  instance:
    preferIpAddress: true
    status-page-url-path: '/'
    instance-id: ${spring.application.name}:${random.long[0,90000000000000000]}
    leaseExpirationDurationInSeconds: 1
    lease-renewal-interval-in-seconds: 1
@spencergibb spencergibb transferred this issue from spring-cloud/spring-cloud-release Dec 23, 2023
@OlgaMaciaszek
Copy link
Collaborator

Hello, @vladgon, thanks for reporting the issue. The premise for native images is the "closed world assumption", which for our purposes means that the application context and bean field values should not change at runtime, which is how the random port was being handled. Do you use the random port in your production applications?

@vladgon
Copy link
Author

vladgon commented Jan 22, 2024 via email

@OlgaMaciaszek
Copy link
Collaborator

We'll definitely be considering various implementation solutions. Please let us know if you use the random port feature in production or just for testing.

@vladgon
Copy link
Author

vladgon commented Jan 22, 2024 via email

@vladgon
Copy link
Author

vladgon commented Jan 22, 2024 via email

@OlgaMaciaszek OlgaMaciaszek self-assigned this Jan 22, 2024
@OlgaMaciaszek OlgaMaciaszek changed the title cannot register to eureka server when spring.cloud.refresh.enabled is false cannot register to eureka server with random port and AOT Sep 30, 2024
@OlgaMaciaszek
Copy link
Collaborator

Hello @vladgon, after discussing within the team, we've decided that given the AOT's/ native closed-world assumptions, it makes sense for us to expect the port to be known in those scenarios, so this is not something we will be handling. Therefore, if you'd like to use AOT/native,we suggest you go away from using random port with your Eureka clients in production.

@vladgon
Copy link
Author

vladgon commented Sep 30, 2024 via email

@OlgaMaciaszek
Copy link
Collaborator

Will add an update. Thanks.

@OlgaMaciaszek OlgaMaciaszek moved this to In Progress in 2023.0.4 Sep 30, 2024
@OlgaMaciaszek OlgaMaciaszek moved this to In Progress in 2024.0.0-M2 Sep 30, 2024
@OlgaMaciaszek OlgaMaciaszek added this to the 4.1.4 milestone Sep 30, 2024
@github-project-automation github-project-automation bot moved this from In Progress to Done in 2024.0.0-M2 Oct 2, 2024
@github-project-automation github-project-automation bot moved this from In Progress to Done in 2023.0.4 Oct 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
No open projects
Status: Done
Status: Done
Development

No branches or pull requests

3 participants