前言
最近在学习如何应用springcloud,当学习到跨服务调用接口时接触到Feign和Ribbon,网上有好多文章是介绍他们俩的区别的,有趣味的能够看看,本文次要举荐应用Feign并记录操作过程。
Feign和Ribbon比照
Ribbon
Ribbon 是一个基于 HTTP 和 TCP 客户端的负载均衡器
它能够在客户端配置 ribbonServerList(服务端列表),而后轮询申请以实现平衡负载
它在联结 Eureka 应用时
ribbonServerList 会被 DiscoveryEnabledNIWSServerList 重写,扩大成从 Eureka 注册核心获取服务端列表
同时它也会用 NIWSDiscoveryPing 来取代 IPing,它将职责委托给 Eureka 来确定服务端是否曾经启动
Feign
Spring Cloud Netflix 的微服务都是以 HTTP 接口的模式裸露的,所以能够用 Apache 的 HttpClient 或 Spring 的 RestTemplate 去調用
而 Feign 是一個应用起來更加不便的 HTTP 客戶端
总结起来就是:公布到注册核心的服务方接口,是 HTTP 的,也能够不必 Ribbon 或者 Feign,间接浏览器一样可能拜访
只不过 Ribbon 或者 Feign 调用起来要不便一些,最重要的是:它俩都反对软负载平衡
留神:spring-cloud-starter-feign 外面曾经蕴含了 spring-cloud-starter-ribbon(Feign 中也应用了 Ribbon)
从实际上看,采纳feign的形式更优雅(feign外部也应用了ribbon做负载平衡)。
操作
1、引入feign依赖包
<dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId></dependency>
2、启用feign:@EnableFeignClients
@SpringBootApplication// 资源爱护服务@EnableResourceServer// 服务发现@EnableDiscoveryClient// 启用feign@EnableFeignClients@RefreshScopepublic class NofityServiceApplication { @Bean public BCryptPasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(); } public static void main(String[] args) { SpringApplication.run(NofityServiceApplication.class, args); }}
3、配置feign传递token
@Configurationpublic class FeignConfig implements RequestInterceptor { @Override public void apply(RequestTemplate requestTemplate) { ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes(); HttpServletRequest request = attributes.getRequest(); String authorization = request.getHeader("authorization"); log.info("--- authorization ---:{}", authorization); if (authorization != null) { log.info(" ---- set authorization ---"); //增加token requestTemplate.header("authorization", authorization); } }}
4、应用feign调用其它微服务接口
新建AccountFeignClient.java文件
@FeignClient("account-service")public interface AccountFeignClient { @GetMapping("/userInfo/{userName}") User getAccountInfoByUserName(@PathVariable("userName") String userName);}
这样就实现了feign配置的所有操作,试试调用是不是OK了!
总结
1、feign跨服务调用的时候会有token的传递,所以肯定要加上下面的config配置
2、如果被调用的服务接口不须要token,如果你调用的接口传递了token会报401,这个要留神一下!
援用
SpringCloud系列之服务生产Ribbon和Feign区别