5.feign整合sentinel
feign整合sentinel
SpringCloud中,微服务调用都是通过Feign来实现的,因此做客户端保护必须整合Feign和Sentinel。
一、修改配置,开启sentinel功能
修改OrderService的application.yml文件,开启Feign的Sentinel功能:
# 配置连接池:
feign:
httpclient:
enabled: true
max-connections: 200
max-connections-per-route: 50
sentinel:
enabled: true # 开启feign对sentinel的支持
二、编写失败降级逻辑
业务失败后,不能直接报错,而应该返回用户一个友好提示或者默认结果,这个就是失败降级逻辑。
给FeignClient编写失败后的降级逻辑
①方式一:FallbackClass,无法对远程调用的异常做处理
②方式二:FallbackFactory,可以对远程调用的异常做处理,我们选择这种
步骤一:在feing-api项目中定义类,实现FallbackFactory:
package cn.itcast.feign.clients.fallback;
import cn.itcast.feign.clients.UserClient;
import cn.itcast.feign.pojo.User;
import feign.hystrix.FallbackFactory;
import lombok.extern.slf4j.Slf4j;
@Slf4j
public class UserClientFallBackFactory implements FallbackFactory<UserClient> {
//feign调用失败,给出友好提示
@Override
public UserClient create(Throwable throwable) {
return new UserClient() {
@Override
public User selectById(Long id) {
log.error("调用userservice服务失败",throwable);
return new User();
}
};
}
}
步骤二:在feing-api项目中的FeignClientConf类中将UserClientFallbackFactory注册为一个Bean:
@Bean
public UserClientFallBackFactory userClientFallBackFactory(){
return new UserClientFallBackFactory();
}
步骤三:在feing-api项目中的UserClient接口中使用UserClientFallbackFactory:
package cn.itcast.feign.clients;
import cn.itcast.feign.clients.fallback.UserClientFallBackFactory;
import cn.itcast.feign.pojo.User;
import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
@FeignClient(value = "userservice",fallbackFactory = UserClientFallBackFactory.class)//引号里面的是要调用的服务名称
public interface UserClient {
@GetMapping("user/{id}")//Controller,请求路径
User selectById(@PathVariable("id") Long id);
}
重启后,访问一次订单查询业务,然后查看sentinel控制台,可以看到新的簇点链路: