spring-cloud ------------------ feign

Feign可以把Rest的请求进行隐藏,伪装成类似SpringMVC的Controller一样。你不用再自己拼接url,拼接参数等等操作,一切都交给Feign去做。

其中支持负载均衡Ribbon、服务熔断Hystix

pom.xml

<!-- feign 内部依赖Ribbon、hystrix 可以不写hystrix依赖 但是Ribbon依赖不可去掉-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

application.yml

feien:
  hystrix:
    enabled: true #开启熔断处理
ribbon: #负载均衡
  ConnectionTimeout: 500  #建立连接时长,超时则抛出异常
  ReadTimeout: 2000 #读取数据时长,超过则抛出异常
hystrix:
  command:
    default:
      execution:
        isolation:
          thread:
            timeoutInMilliseconds: 6000 
# 设置hystrix的超时时间为6000ms   (ConnectionTimeout+ReadTimeout) *2 不能超过timeoutInMilliseconds
  • 首先这是一个接口,Feign会通过动态代理,帮我们生成实现类。这点跟mybatis的mapper很像
  • @FeignClient,声明这是一个Feign客户端,类似@Mapper注解。同时通过value属性指定服务名称
  • 接口中的定义方法,完全采用SpringMVC的注解,Feign会根据注解帮我们生成URL,并访问获取结果
@FeignClient(value = "user-service",fallback = UserClientFallback.class) 
//feign会通过user-service服务名称去eureka注册中心去拉去相应的服务列表
//并通过Ribbon提供的负载均衡算法选取一个服务,继而获得服务的地址,通过GetMapper获得路径出入参数获
//得返回值.
//fallback为熔断处理结果的内容类 实现此接口实现方法。
public interface UserFeignClient {

    @GetMapping("/user/{id}")
    User queryUserById(@PathVariable("id") Long id);
}

实现类

public class UserClientFallback implements UserClient {
    @Override
    public String queryById(int id) {
        return "服务器忙啊";
    }
}

开启feign

@EnableFeignClients //开启feign
@SpringCloudApplication
public class ConsumerApplication {

    public static void main(String[] args){
        SpringApplication.run(ConsumerApplication.class);
    }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值