springCloud-22 feign和ribbon的联系 负载均衡

一,feign 和ribbon 的联系        

  • Ribbon是一个基于 HTTP TCP 客户端 的负载均衡的工具。它可以 在客户端 配置 RibbonServerList(服务端列表),使用 HttpClient RestTemplate 模拟http请求,步骤相当繁琐。
  • Feign 是在 Ribbon的基础上进行了一次改进,是一个使用起来更加方便的 HTTP 客户端。采用接口的 方式, 只需要创建一个接口,然后在上面添加注解即可 ,将需要调用的其他服务的方法定义成抽象方法即可,不需要自己构建http请求。然后就像是调用自身工程的方法调用,而感觉不到是调用远程方法,使得编写客户端变得非常容易

二,feign 负载均衡

        Feign中本身已经集成了 Ribbon依赖和自动配置,因此我们不需要额外引入依赖,也不需要再注册RestTemplate 对象。另外,我们可以像上节课中讲的那样去配置 Ribbon ,可以通过 ribbon.xx 来进行全局配置。也可以通过 服务名 .ribbon.xx 来对指定服务配置:
启动两个 shop_service_product ,重新测试可以发现使用 Ribbon 的轮询策略进行负载均衡

Feign 是可以更加方便让服务消费者请求服务提供者,并且自带了ribbon 的轮询策略 ,如果想改变负载均衡策略。可以在配置文件里添加ribbon配置,来改变负载均衡策略。

feign: 
    client: 
        config: 
            feignName: ##定义FeginClient的名称 
                connectTimeout: 5000 # 相当于Request.Options 
                readTimeout: 5000 # 相当于Request.Options 
                # 配置Feign的日志级别,相当于代码配置方式中的Logger 
                loggerLevel: full # Feign的错误解码器,相当于代码配置方式中的ErrorDecoder             
                errorDecoder: com.example.SimpleErrorDecoder #配置重试,相当于代码配置方式中的Retryer 
                retryer: com.example.SimpleRetryer # 配置拦截器,相当于代码配置方式中的RequestInterceptor 
                requestInterceptors: 
                    - com.example.FooRequestInterceptor 
                    - com.example.BarRequestInterceptor 
                decode404: false
  • feignNameFeginClient的名称
  • connectTimeout : 建立链接的超时时长
  • readTimeout : 读取超时时长
  • loggerLevel: Fegin的日志级别
  • errorDecoder Feign的错误解码器
  • retryer : 配置重试
  • requestInterceptors : 添加请求拦截器
  • decode404 : 配置熔断不处理404异常
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

vegetari

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值