错误:Caused by: org.apache.http.conn.ConnectTimeoutException: Connect to localhost:8761 timed out

详细错误:

 1 com.sun.jersey.api.client.ClientHandlerException: org.apache.http.conn.ConnectTimeoutException: Connect to localhost:8761 timed out
 2     at com.sun.jersey.client.apache4.ApacheHttpClient4Handler.handle(ApacheHttpClient4Handler.java:187) ~[jersey-apache-client4-1.19.1.jar:1.19.1]
 3     at com.netflix.eureka.cluster.DynamicGZIPContentEncodingFilter.handle(DynamicGZIPContentEncodingFilter.java:48) ~[eureka-core-1.7.2.jar:1.7.2]
 4     at com.netflix.discovery.EurekaIdentityHeaderFilter.handle(EurekaIdentityHeaderFilter.java:27) ~[eureka-client-1.7.2.jar:1.7.2]
 5     at com.sun.jersey.api.client.Client.handle(Client.java:652) ~[jersey-client-1.19.1.jar:1.19.1]
 6     at com.sun.jersey.api.client.WebResource.handle(WebResource.java:682) ~[jersey-client-1.19.1.jar:1.19.1]
 7     at com.sun.jersey.api.client.WebResource.access$200(WebResource.java:74) ~[jersey-client-1.19.1.jar:1.19.1]
 8     at com.sun.jersey.api.client.WebResource$Builder.post(WebResource.java:570) ~[jersey-client-1.19.1.jar:1.19.1]
 9     at com.netflix.eureka.transport.JerseyReplicationClient.submitBatchUpdates(JerseyReplicationClient.java:116) ~[eureka-core-1.7.2.jar:1.7.2]
10     at com.netflix.eureka.cluster.ReplicationTaskProcessor.process(ReplicationTaskProcessor.java:71) ~[eureka-core-1.7.2.jar:1.7.2]
11     at com.netflix.eureka.util.batcher.TaskExecutors$BatchWorkerRunnable.run(TaskExecutors.java:187) [eureka-core-1.7.2.jar:1.7.2]
12     at java.lang.Thread.run(Thread.java:748) [na:1.8.0_202]
13 Caused by: org.apache.http.conn.ConnectTimeoutException: Connect to localhost:8761 timed out
14     at org.apache.http.conn.scheme.PlainSocketFactory.connectSocket(PlainSocketFactory.java:123) ~[httpclient-4.5.8.jar:4.5.8]
15     at org.apache.http.impl.conn.DefaultClientConnectionOperator.openConnection(DefaultClientConnectionOperator.java:180) ~[httpclient-4.5.8.jar:4.5.8]
16     at org.apache.http.impl.conn.AbstractPoolEntry.open(AbstractPoolEntry.java:144) ~[httpclient-4.5.8.jar:4.5.8]
17     at org.apache.http.impl.conn.AbstractPooledConnAdapter.open(AbstractPooledConnAdapter.java:134) ~[httpclient-4.5.8.jar:4.5.8]
18     at org.apache.http.impl.client.DefaultRequestDirector.tryConnect(DefaultRequestDirector.java:605) ~[httpclient-4.5.8.jar:4.5.8]
19     at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:440) ~[httpclient-4.5.8.jar:4.5.8]
20     at org.apache.http.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:835) ~[httpclient-4.5.8.jar:4.5.8]
21     at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:118) ~[httpclient-4.5.8.jar:4.5.8]
22     at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:56) ~[httpclient-4.5.8.jar:4.5.8]
23     at com.sun.jersey.client.apache4.ApacheHttpClient4Handler.handle(ApacheHttpClient4Handler.java:173) ~[jersey-apache-client4-1.19.1.jar:1.19.1]
24     ... 10 common frames omitted

疑问:我哪里根本没有使用到端口为:8761  的应用,经过一番百度查阅,终于让我找到答案了。原来问题出在  EurekaClientConfigBean 这个类,源码如下:

 1 package org.springframework.cloud.netflix.eureka;
 2 import ...
 3 @ConfigurationProperties("eureka.client")
 4 public class EurekaClientConfigBean implements EurekaClientConfig {
 5     public static final String PREFIX = "eureka.client";
 6     public static final String DEFAULT_URL = "http://localhost:8761/eureka/";  // 问题的所在,原来 springcloud 源码这里定义了
 7     public static final String DEFAULT_ZONE = "defaultZone";
 8     private static final int MINUTES = 60;
 9     @Autowired(
10         required = false
11     )
12     .....
13     public EurekaClientConfigBean() {
14         this.serviceUrl.put("defaultZone", "http://localhost:8761/eureka/");
15         this.gZipContent = true;
16         this.useDnsForFetchingServiceUrls = false;
17         this.registerWithEureka = true;
18         this.preferSameZoneEureka = true;
19         this.availabilityZones = new HashMap();
20         this.filterOnlyUpInstances = true;
21         this.fetchRegistry = true;
22         this.dollarReplacement = "_-";
23         this.escapeCharReplacement = "__";
24         this.allowRedirects = false;
25         this.onDemandUpdateStatusChange = true;
26         this.clientDataAccept = EurekaAccept.full.name();
27         this.shouldUnregisterOnShutdown = true;
28         this.shouldEnforceRegistrationAtInit = false;
29     }
30     ...
31 }

解决方案:使用你的端口号去覆盖里面的端口,即:

eureka.client.service-url.defaultZone=http://eureka1:5121/eureka/  // 写你的ip及端口

猜你喜欢

转载自www.cnblogs.com/maigy/p/11042210.html
今日推荐