记一次springcloud的feign调用报错exception is feign.RetryableException: Read timed out executing POST http://

问题出现在:eureka.instance.non-secure-port=80这个配置上,解决这个问题之前不了解这个配置的作用,自动忽略了
情况描述:
使用@feignclient调用服务提供者,但是每次都报标题所记错误,搜索的类似错误,都是要修改超时时间,但是我把@feignclient中的value修改为开发环境的应用名称是正常的(开发环境用的类似于${server.port},报错是因为我本地修改了启动端口,而这个配置存在着),就调试了代码,看到serverlist中的port是80端口,类名为CachingSpringLoadBalancerFactory
记一次springcloud的feign调用报错exception is feign.RetryableException: Read timed out executing POST http://_第1张图片
就很奇怪,80是哪里冒出来的?
找到了serverList初始赋值的地方
DiscoveryEnabledNIWSServerList.obtainServersViaDiscovery()
记一次springcloud的feign调用报错exception is feign.RetryableException: Read timed out executing POST http://_第2张图片
这里仍然是80端口,然后才回头试着修改的配置文件即

eureka.instance.non-secure-port=80

才有的一次成功
【补充】
在服务端和客户端都需要eureka.instance.non-secure-port 相同,否则还是调用不通

了解eureka.instance.non-secure-port可以参考
https://www.cnblogs.com/xiaopaodeboke/p/9181701.html
https://blog.csdn.net/shog808/article/details/77161071

你可能感兴趣的:(springcloud,springcloud实践)