com.netflix.discovery.shared.transport.TransportException: Cannot execute request on any known serve

问题描述:

使用java -jar启动Eureka Server集群程序时,控制台报出了以下错误:

Caused by: java.net.ConnectException: Connection refused (Connection refused)
    at java.net.PlainSocketImpl.socketConnect(Native Method) ~[na:1.8.0_161]
    at java.net.AbstractPlainSocketImpl.doConnect(AbstractPlainSocketImpl.java:350) ~[na:1.8.0_161]
    at java.net.AbstractPlainSocketImpl.connectToAddress(AbstractPlainSocketImpl.java:206) ~[na:1.8.0_161]
    at java.net.AbstractPlainSocketImpl.connect(AbstractPlainSocketImpl.java:188) ~[na:1.8.0_161]
    at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:392) ~[na:1.8.0_161]
    at java.net.Socket.connect(Socket.java:589) ~[na:1.8.0_161]
    at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:117) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:177) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:144) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:131) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.client.DefaultRequestDirector.tryConnect(DefaultRequestDirector.java:611) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:446) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:882) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:117) ~[httpclient-4.5.1.jar!/:4.5.1]
    at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:55) ~[httpclient-4.5.1.jar!/:4.5.1]
    at com.sun.jersey.client.apache4.ApacheHttpClient4Handler.handle(ApacheHttpClient4Handler.java:173) ~[jersey-apache-client4-1.19.1.jar!/:1.19.1]
    ... 29 common frames omitted

2018-07-22 16:29:18.267  WARN 7831 --- [nfoReplicator-0] c.n.d.s.t.d.RetryableEurekaHttpClient    : Request execution failed with message: java.net.ConnectException: Connection refused (Connection refused)
2018-07-22 16:29:18.268  WARN 7831 --- [nfoReplicator-0] com.netflix.discovery.DiscoveryClient    : DiscoveryClient_EUREKA-SERVER-PEER/192.168.1.3:eureka-server-peer:8762 - registration failed Cannot execute request on any known server

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.7.0.jar!/:1.7.0]
    at com.netflix.discovery.shared.transport.decorator.EurekaHttpClientDecorator.register(EurekaHttpClientDecorator.java:56) ~[eureka-client-1.7.0.jar!/:1.7.0]
    at com.netflix.discovery.shared.transport.decorator.EurekaHttpClientDecorator$1.execute(EurekaHttpClientDecorator.java:59) ~[eureka-client-1.7.0.jar!/:1.7.0]
    at com.netflix.discovery.shared.transport.decorator.SessionedEurekaHttpClient.execute(SessionedEurekaHttpClient.java:77) ~[eureka-client-1.7.0.jar!/:1.7.0]
    at com.netflix.discovery.shared.transport.decorator.EurekaHttpClientDecorator.register(EurekaHttpClientDecorator.java:56) ~[eureka-client-1.7.0.jar!/:1.7.0]
    at com.netflix.discovery.DiscoveryClient.register(DiscoveryClient.java:807) ~[eureka-client-1.7.0.jar!/:1.7.0]
    at com.netflix.discovery.InstanceInfoReplicator.run(InstanceInfoReplicator.java:104) [eureka-client-1.7.0.jar!/:1.7.0]
    at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java:511) [na:1.8.0_161]
    at java.util.concurrent.FutureTask.run(FutureTask.java:266) [na:1.8.0_161]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.access$201(ScheduledThreadPoolExecutor.java:180) [na:1.8.0_161]
    at java.util.concurrent.ScheduledThreadPoolExecutor$ScheduledFutureTask.run(ScheduledThreadPoolExecutor.java:293) [na:1.8.0_161]
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) [na:1.8.0_161]
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) [na:1.8.0_161]
    at java.lang.Thread.run(Thread.java:748) [na:1.8.0_161]

问题原因

导致此问题的原因是因为,Eureka Server 在启动时也将自身做为服务向注册中心注册了,所以需要禁用该属性

解决方案

application.yml配置文件中增加如下配置

eureka:
  client:
    register-with-eureka: false # 表示不向注册中心注册
    fetch-registry: false # 由于注册中心的职责就是维护服务实例,所以它不需要去检索服务
  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
### 回答1: 这个错误通常是由于Netflix Eureka Client无法连接到Eureka Server引起的。 这可能是由于以下原因之一: 1. Eureka Server未运行或配置不正确。 2. Eureka Client配置不正确,无法找到正确的Eureka Server URL。 3. 网络问题。 为了解决这个问题,您可以尝试以下步骤: 1. 确认Eureka Server正在运行,并且其配置正确。 2. 确认Eureka Client的配置正确,并且其可以找到正确的Eureka Server URL。 3. 检查网络连接,确保网络没有问题。 如果您遵循上述步骤仍然无法解决问题,请检查您的日志文件以获取更多信息。 ### 回答2: "com.netflix.discovery.shared.transport.TransportException: Cannot execute request on any known server" 是Netflix Ribbon中的一个异常,它表示无法在已知的服务上执行请求。 Netflix Ribbon是Netflix开发的负载均衡库,用于在分布式系统中管理和调节服务之间的流量。当发起请求时,Ribbon会从服务注册中心获取可用的服务实例,并根据负载均衡算法选择一个实例来处理请求。然而,当出现"Cannot execute request on any known server"异常时,意味着Ribbon无法找到任何可用的服务实例来处理请求。 造成此异常的原因通常有以下几种: 1. 服务实例不可用:可能是因为服务实例宕机、网络不可达或者服务没有正确注册到服务注册中心。 2. 服务注册中心配置错误:可能是由于配置错误导致Ribbon无法正确获取可用的服务实例信息。 3. Ribbon配置错误:可能是因为配置文件中的属性值错误或者缺失,导致Ribbon无法正确执行负载均衡算法或者选择可用的服务实例。 要解决该问题,可以采取以下措施: 1. 检查服务实例的可用性:确保服务实例正常运行,并可以通过网络访问。 2. 检查服务注册中心配置:确认服务注册中心的地址和端口是否正确配置,并重新启动Ribbon。 3. 检查Ribbon配置:查看Ribbon配置文件,确保属性值正确配置,并符合业务需求。 通过以上步骤的检查和调试,应该能够解决"com.netflix.discovery.shared.transport.TransportException: Cannot execute request on any known server"异常。如果问题仍然存在,可以参考Netflix Ribbon的官方文档或者在相关技术社区进行咨询寻求帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值