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控制台,可以看到新的簇点链路:

 
                    
                     
                    
                 
                    
                
 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号