springcloud Feign的玩法(做笔记)

在customer pom文件中加入

      <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
      </dependency>

在yml文件中加入

feign:
  hystrix:
    enabled: true # 开启Feign的熔断功能
@SpringCloudApplication
@EnableFeignClients //启用feign组件 有了这注解,注释掉代码段1 因为feign本身里面就综合了负载均衡
public class ItcastServiceCustomerApplication {

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

}
其中
@SpringCloudApplication=====
@SpringBootApplication @EnableDiscoveryClient @EnableCircuitBreaker

创建一个client包下的UserClient接口

//首先这是一个接口,Feign会通过动态代理,帮我们生成实现类。这点跟mybatis的mapper很像
//这里不要使用RequestMapping,会报错

@FeignClient(value = "service-provider",fallback = UserClientFallback.class)
public interface UserClient {

    @GetMapping("user/{id}")
    public User queryUserById(@RequestParam("id")Long id); //和provider里的controller方法一样
}

再写UserClient的实现类,一起放在client包下

@Component //注入容器
public class UserClientFallback implements UserClient{

    @Override
    public User queryUserById(Long id) {
        User user = new User();
        user.setUsername("服务器正忙,请稍后再试");
        return user;
    }
}

UserController中

@RestController
@RequestMapping("customer/user")
//@DefaultProperties(defaultFallback = "fallbackMethod") //定义全局熔断方法 熔断方法的参数为空
public class Usercontroller {

    @Autowired
    private UserClient userClient;


    @GetMapping
    @HystrixCommand //哪个方法要熔断,就必须要加这个注解
    public String queryUserById(@RequestParam("id")Long id){
 
        return this.userClient.queryUserById(id).toString();

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值