В моем клиентском классе есть поле @Autowired типа com.netflix.discovery.DiscoveryClient, которое используется для общения с Eureka и запроса к нему информации о других службах. В моем основном классе есть аннотация @EnableDiscoveryClient:
Код: Выделить всё
@SpringBootApplication
@EnableDiscoveryClient
public class AppBootstrap {
public static void main(String[] args) {
SpringApplication.run(AppBootstrap.class, args);
}
}
Код: Выделить всё
eureka:
instance:
lease-renewal-interval-in-seconds: 10
lease-expiration-duration-in-seconds: 20
prefer-ip-address: true
secure-port: 443
non-secure-port: 80
metadata-map:
instanceId: my-test-instance
client:
service-url:
defaultZone: http://localhost:9080/eureka/
registry-fetch-interval-seconds: 6
instance-info-replication-interval-seconds: 6
register-with-eureka: true
fetch-registry: true
heartbeat-executor-thread-pool-size: 5
eureka-service-url-poll-interval-seconds: 10
Вызвано: java.lang.AbstractMethodError: org.springframework.cloud.netflix.eureka.EurekaInstanceConfigBean.getInstanceI
d()Ljava/lang/String;
на com.netflix.appinfo.providers.EurekaConfigBasedInstanceInfoProvider.get(EurekaConfigBasedInstanceInfoProvider
.java:53)
на com.netflix.appinfo.ApplicationInfoManager.initComponent(ApplicationInfoManager.java:90)
... еще 25
Я понятия не имею, что здесь происходит. Есть идеи? Я считаю, что приложение все равно должно запуститься, даже если моя конфигурация Eureka неверна, но оно зависает во время запуска.
Во-вторых, использую ли я правильный DiscoveryClient? В идеале я хотел бы сделать его общим, чтобы я мог использовать его с Eureka, Consul или ZooKeeper в качестве примеров. Я считаю, что документация не очень хорошо объясняет, что именно требуется при использовании этих компонентов обнаружения Spring Cloud / Netflix.
Мобильная версия