com.netflix.discovery.shared.transport.TransportException:无法在任何已知服务器上执行请求
Posted
技术标签:
【中文标题】com.netflix.discovery.shared.transport.TransportException:无法在任何已知服务器上执行请求【英文标题】:com.netflix.discovery.shared.transport.TransportException: Cannot execute request on any known server 【发布时间】:2018-02-18 05:58:27 【问题描述】:我对微服务非常陌生,并尝试从链接运行代码:https://dzone.com/articles/advanced-microservices-security-with-spring-and-oa。当我简单地运行代码时,我看到以下错误出现。
有什么问题?
com.netflix.discovery.shared.transport.TransportException: Cannot execute request on any known server
at com.netflix.discovery.shared.transport.decorator.RetryableEurekaHttpClient.execute(RetryableEurekaHttpClient.java:111) ~[eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.shared.transport.decorator.EurekaHttpClientDecorator.getApplications(EurekaHttpClientDecorator.java:134) ~[eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.shared.transport.decorator.EurekaHttpClientDecorator$6.execute(EurekaHttpClientDecorator.java:137) ~[eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.shared.transport.decorator.SessionedEurekaHttpClient.execute(SessionedEurekaHttpClient.java:77) ~[eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.shared.transport.decorator.EurekaHttpClientDecorator.getApplications(EurekaHttpClientDecorator.java:134) ~[eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.DiscoveryClient.getAndStoreFullRegistry(DiscoveryClient.java:1030) [eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.DiscoveryClient.fetchRegistry(DiscoveryClient.java:944) [eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.DiscoveryClient.refreshRegistry(DiscoveryClient.java:1468) [eureka-client-1.4.12.jar:1.4.12]
at com.netflix.discovery.DiscoveryClient$CacheRefreshThread.run(DiscoveryClient.java:1435) [eureka-client-1.4.12.jar:1.4.12]
at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) [na:1.8.0_144]
at java.util.concurrent.FutureTask.run(Unknown Source) [na:1.8.0_144]
at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) [na:1.8.0_144]
at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) [na:1.8.0_144]
at java.lang.Thread.run(Unknown Source) [na:1.8.0_144]
2017-09-09 18:53:11.909 ERROR 16268 --- [tbeatExecutor-0] c.n.d.s.t.d.RedirectingEurekaHttpClient : Request execution error
我没有在系统上安装任何特殊的东西。请让我知道我需要安装什么?
【问题讨论】:
【参考方案1】:在 application.properties 中添加以下行解决了它:
server.port=8761
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
第一个是可选的。
另外两个属性用来告诉Eureka Server“嘿,你是这个上下文中唯一的Eureka Server,不要试图去寻找其他的Eureka Server”
如果我们不提及这些,我们的 Eureka Server 会尝试在其他 Eureka Server 上查找并注册自己,最终会抛出 Transport Exception。
【讨论】:
【参考方案2】:我遇到了同样的错误。就我而言,在我的客户端应用程序的application.properties
文件中,我拼错了defaultZone
单词。我写了default-zone
,但它必须是defaultZone
。
客户端应用 application.properties
:
eureka.client.service-url.defaultZone=http://localhost:8030/eureka/
主机名和端口可能因您的情况而异。
【讨论】:
【参考方案3】:依赖版本:
春季启动:2.5.6
春云:2020.0.4
尤里卡服务器应用
application.yaml
server:
port: 8010
eureka:
client:
fetch-registry: false
register-with-eureka: false
service-url:
defaultZone: http://localhost:8010/eureka
MyEurekaClientApplication.java
@EnableEurekaServer
@SpringBootApplication
public class MyEurekaServerApplication
public static void main(String[] args)
SpringApplication.run(MyEurekaServerApplication.class, args);
尤里卡客户端应用
application.yaml
eureka:
client:
service-url:
defaultZone: http://localhost:8010/eureka
如果你使用default-zone
而不是defaultZone
,那么Eureka Client App在Eureka Server上注册时会抛出异常。
MyEurekaClientApplication.java
@EnableEurekaClient
@SpringBootApplication
public class MyEurekaClientApplication
public static void main(String[] args)
SpringApplication.run(MyEurekaClientApplication.class, args);
【讨论】:
【参考方案4】:如果您在 defaultZone 的值中拼错任何内容,也会引发类似的错误。例如:有人将 eureka 拼错为 euraka。仔细检查一下。
defaultZone : http://localhost:8761/eureka
【讨论】:
【参考方案5】:当我的 Eureka 客户端(即微服务尝试向 Eureka Server 注册自己)时,我遇到了同样的错误。
客户端注册eureka服务失败注册失败无法在任何已知服务器上执行请求
出现此错误消息是因为以下两种可能性。
1) defaultZone 地址不正确,可能是拼写错误,或者:后面的空格缺失。
2) 在 Eureka 服务器上实现的 Spring 安全性要求每个请求都发送一个有效的 CSRF 令牌。 Eureka 客户端通常不会拥有有效的跨站请求伪造 (CSRF) 令牌。因此,您需要为 /eureka/** 端点禁用此要求。
在使用以下代码行禁用 CSRF 令牌后,我的 Eureka 客户端成功地将它们自己注册到 Eureka Server。
@EnableWebSecurity
class WebSecurityConfig extends WebSecurityConfigurerAdapter
@Override
protected void configure(HttpSecurity http) throws Exception
http.csrf().ignoringAntMatchers("/eureka/**");
super.configure(http);
下面还有来自 spring 文档的链接。
https://cloud.spring.io/spring-cloud-static/Greenwich.SR2/single/spring-cloud.html#_securing_the_eureka_server
【讨论】:
您能告诉我们您尝试过的 Spring Boot 和 Spring Cloud 版本吗?我有同样的问题,罪魁祸首是弹簧安全。我已经尝试过您的解决方案,但没有区别。我已经看过文档和github.com/spring-cloud/spring-cloud-netflix/issues/2754。没有不同。顺便说一句,我的spring-boot
版本是:2.5.2 和spring-cloud
版本是:2020.0.3
@MortezaBandi 我的固定解决方案是使用 spring-boot 2.2.6.RELEASE 和 spring-cloud Hoxton.SR3【参考方案6】:
对我来说它在连接到互联网后工作,因为它需要第一次下载一些依赖项。
【讨论】:
【参考方案7】:检查你的 eureka 服务器的 URL 和端口号 在“eureka.client.serviceUrl.defaultZone”属性中提供。
【讨论】:
【参考方案8】:如果您的 eureka 服务器在没有用户名和密码的情况下部署/运行,请使用以下属性。
spring.application.name=Hello-World
eureka.client.serviceUrl.defaultZone=http://eurekaserver:password@localhost:9100/eureka
server.port=9200
eureka.client.fetch-registry=true
如果您的 eureka 服务器使用用户名和密码部署/运行,请使用以下属性。
spring.application.name=Hello-World
eureka.client.serviceUrl.defaultZone=http://eurekaserverusername:eurekaserverpassword@localhost:9100/eureka
server.port=9200
eureka.client.fetch-registry=true
【讨论】:
【参考方案9】:在 ZuulLoggingFiler.java 中查找 filterType()。我有同样的问题。然后我看到我的过滤器返回 null。所以我把它改成了“post”,它起作用了。
@Override
public String filterType()
// TODO Auto-generated method stub
return "post";
【讨论】:
【参考方案10】:我发现我必须将这两个应用程序添加到appllication.properties,它才能工作。只有一个是不够的。
eureka.client.register-with-eureka=false
eureka.client.fetch-registry=false
【讨论】:
这帮助我解决了我的问题,感谢@xuezhongyu01 谢谢...这是正确答案...eureka.client.fetch-registry=false
将此行包含在我的尤里卡微服务中。
是的,但这实质上使该客户端无法被发现。那是理想的吗?也许对于这种情况......对我来说,它本质上是:1)首先启动@EnableEurekaServer
应用程序; 2) 之后启动任何@EurekaDiscoveryClient
应用程序。这主要是一个时间问题(尝试连接,失败,再试,失败,再试,成功)
澄清一下,上面的两个属性是在eureka服务器内部使用的,而不是客户端。这可以防止服务器自行注册。
感谢 eureka.client.register-with-eureka=false 解决了我的问题。【参考方案11】:
发生这种情况是因为它正在尝试连接到任何已知服务器,因此要停止该错误,已知服务器是端口 8761 上的 eureka 服务器,这是其默认端口,您必须使用以下内容更新 application.properties
server.port=8761
为避免 eureka 自行注册,请将其添加到 application.properties
eureka.client.register-with-eureka=false
确保 EurekaServer 已启用,例如使用 spring boot 你在主类上编写以下内容。
@EnableEurekaServer
请原谅我使用 .properties 文件提供解决方案,但这是我使用的,但 .yml 配置不应有太大不同。
【讨论】:
【参考方案12】:您需要创建另一个微服务 Eureka Registry Server。它是 SpringBoot 应用程序的主类,应该有 @EnableEurekaServer 注释。
然后在您的 Eureka 客户端中,您必须在 appliation.yml 中提及注册表服务器 URL,如下所示:
spring:
application:
name: stock-service
server:
port: 8083
eureka:
client:
registerWithEureka: true
fetchRegistry: true
serviceUrl:
defaultZone: http://localhost:8084/eureka/
instance:
hostname: localhost
defaultzone 应该保存你的 Eureka Registry 的值。
完成所有这些配置后,您需要启动 Eureka Registry 微服务,然后您就可以启动 Eureka 客户端。注册表启动后,您将不会遇到此异常。
【讨论】:
【参考方案13】:此特定消息只是一个警告。您的应用程序正在尝试向 Eureka 注册,但 Eureka 没有响应。您可以启动 Eureka 实例或通过将以下内容添加到 application.yml 来禁用自动注册。
eureka:
client:
register-with-eureka: false
【讨论】:
哦,我想我的 Windows 盒子上没有安装 Eureka?那是问题吗?我需要安装它吗? 您的工作可能不需要它。只需禁用它,这样您就不会每 5 秒看到一条消息。如果您想了解有关 Eureka 的更多信息,请从这里开始 (spring.io/guides/gs/service-registration-and-discovery)以上是关于com.netflix.discovery.shared.transport.TransportException:无法在任何已知服务器上执行请求的主要内容,如果未能解决你的问题,请参考以下文章