1.FeignClient整合Sentinel
SpringCloud中,微服务调用都是通过Feign来实现的,因此做客户端保护必须整合Feign和Sentinel。
1.1.修改配置,开启sentinel功能
修改OrderService的application.yml文件,开启Feign的Sentinel功能:
feign:
sentinel:
enabled: true # 开启feign对sentinel的支持
1.2.编写失败降级逻辑
业务失败后,不能直接报错,而应该返回用户一个友好提示或者默认结果,这个就是失败降级逻辑。
给FeignClient编写失败后的降级逻辑
-
方式一:
FallbackClass,无法对远程调用的异常做处理 -
方式二:
FallbackFactory,可以对远程调用的异常做处理,我们选择这种
这里我们演示方式二的失败降级处理。
步骤一:在feing-api项目中定义类,实现FallbackFactory:

代码:
package com.dcxuexi.feignapi.client.fallback;
import com.dcxuexi.feignapi.client.UserClient;
import com.dcxuexi.feignapi.pojo.User;
import feign.hystrix.FallbackFactory;
import lombok.extern.slf4j.Slf4j;
/***
* @Title UserClientFallbackFactory
* @Description TOTD
* @Auter DongChuang
* @Date 2023/5/8 21:03
* @Version 1.0.0
*/
@Slf4j
public class UserClientFallbackFactory implements FallbackFactory<UserClient>

最低0.47元/天 解锁文章
3947

被折叠的 条评论
为什么被折叠?



