SpringCloud Gateway 项目动态路由转发报错java.net.UnknownHostException:xxx

背景:已有一个eurekaServer,两个服务提供者BizServer8762和BizServer8763,一个服务消费者BizClient(ribbon+resttemplate+hystrix):
例子为:外部请求通过gateway路由转发到服务消费者,再请求到服务提供者,
在这里插入图片描述

SpringCloud Gateway 项目application配置文件如下:

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/ #服务注册地址为http://localhost:8761/eureka/
server:
  port: 8766
spring:
  application:
    name: servicegateway
  cloud:
    gateway:
      routes: # 路由可以有多个,路由由id+url+断言组成
        - id: biz-service-router # 我们⾃定义的路由 ID,保持唯⼀
          uri: http://bizClient 
          predicates: #断⾔:路由条件,Predicate 接受⼀个输⼊参数,返回⼀个布尔值结果。该接口包含多种默认⽅法来将 Predicate 组合成其他复杂的逻辑(⽐如:与,或,⾮)。
            - Path=/client/**
#          filters:
#            - StripPrefix=1 # #转发请求时去掉1级前缀,去掉端口后的第一个节点,这里是client
  #上⾯这段配置的意思是,配置了⼀个 id 为 biz-service-router 的路由规
  #则,当向⽹关发起请求 http://localhost:8766/client/callServer?name=ribbon,请求会被分发路由到对应的微服务上http://bizClient/client/callServer?name=ribbon---->http://localhost:8764/client/callServer?name=ribbon

请求报错

java.net.UnknownHostException: bizClient
	at java.base/java.net.InetAddress$CachedAddresses.get(InetAddress.java:796) ~[na:na]
	at java.base/java.net.InetAddress.getAllByName0(InetAddress.java:1504) ~[na:na]
	at java.base/java.net.InetAddress.getAllByName(InetAddress.java:1363) ~[na:na]
	at java.base/java.net.InetAddress.getAllByName(InetAddress.java:1297) ~[na:na]
	at java.base/java.net.InetAddress.getByName(InetAddress.java:1247) ~[na:na]
	at io.netty.util.internal.SocketUtils$8.run(SocketUtils.java:146) ~[netty-common-4.1.25.Final.jar:4.1.25.Final]
	at io.netty.util.internal.SocketUtils$8.run(SocketUtils.java:143) ~[netty-common-4.1.25.Final.jar:4.1.25.Final]
	at java.base/java.security.AccessController.doPrivileged(Native Method) ~[na:na]
	at io.netty.util.internal.SocketUtils.addressByName(SocketUtils.java:143) ~[netty-common-4.1.25.Final.jar:4.1.25.Final]
	at io.netty.resolver.DefaultNameResolver.doResolve(DefaultNameResolver.java:43) ~[netty-resolver-4.1.25.Final.jar:4.1.25.Final]
	at io.netty.resolver.SimpleNameResolver.resolve(SimpleNameResolver.java:63) ~[netty-resolver-4.1.25.Final.jar:4.1.25.Final]
	at io.netty.resolver.SimpleNameResolver.resolve(SimpleNameResolver.java:55) ~[netty-resolver-4.1.25.Final.jar:4.1.25.Final]
	at io.netty.resolver.InetSocketAddressResolver.doResolve(InetSocketAddressResolver.java:57) ~[netty-resolver-4.1.25.Final.jar:4.1.25.Final]
	at io.netty.resolver.InetSocketAddressResolver.doResolve(InetSocketAddressResolver.java:32) ~[netty-resolver-4.1.25.Final.jar:4.1.25.Final]
	at io.netty.resolver.AbstractAddressResolver.resolve(AbstractAddressResolver.java:108) ~[netty-resolver-4.1.25.Final.jar:4.1.25.Final]

原因:application配置错误
在这里插入图片描述
真确如下:
在这里插入图片描述
正确配置如下:

eureka:
  client:
    serviceUrl:
      defaultZone: http://localhost:8761/eureka/ #服务注册地址为http://localhost:8761/eureka/
server:
  port: 8766
spring:
  application:
    name: servicegateway
  cloud:
    gateway:
      routes: # 路由可以有多个,路由由id+url+断言组成
        - id: biz-service-router # 我们⾃定义的路由 ID,保持唯⼀
          uri: lb://bizClient # 格式:lb://服务名,--》 lb是loadbalancer缩写,
#          注意:动态路由设置时,uri以 lb: //开头(lb代表从注册中心获取服务),后面是
#    需要转发到的服务名称,⽬标服务地址 服务提供者微服务(部署多实例) 动态路由:uri配置的应该是⼀个服务名称,⽽不应该是⼀个具体的服务实例的地址
          predicates: #断⾔:路由条件,Predicate 接受⼀个输⼊参数,返回⼀个布尔值结果。该接口包含多种默认⽅法来将 Predicate 组合成其他复杂的逻辑(⽐如:与,或,⾮)。
            - Path=/client/**
#          filters:
#            - StripPrefix=1 # #转发请求时去掉1级前缀,去掉端口后的第一个节点,这里是client
  #上⾯这段配置的意思是,配置了⼀个 id 为 biz-service-router 的路由规
  #则,当向⽹关发起请求 http://localhost:8766/client/callServer?name=ribbon,请求会被分发路由到对应的微服务上http://bizClient/client/callServer?name=ribbon---->http://localhost:8764/client/callServer?name=ribbon
  • 7
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值