Spring Cloud源码解析
- 什么是Feign
feign 是一种声明式的web 客户端,可以使用它的注解创建接口,它也支持
自定义编解码。Spring Cloud 集成了Ribbon 和Eureka 为客户端提供了负载均衡策略。Feign有两个主要注解: (@EnableFeignClients 用于开启feign功能,@FeignClient 用于定义feign 接口)。
feign底层是使用了ribbon作为负载均衡的客户端,而ribbon的负载均衡也是依赖于eureka 获得各个服务的地址,所以一般和eureka-client一起使用。
- 作用
feign是声明式的web service客户端,它让微服务之间的调用变得更简单
了,类似controller调用service。Spring Cloud集成了Ribbon和Eureka,可在使用Feign时提供负载均衡的http客户端。使用feign之后,我们调用eureka 注册的其他服务,在代码中就像各个service之间相互调用那么简单。
- 原理简述
- 启动时,程序会进行包扫描,扫描所有包下所有@FeignClient注解的类,
并将这些类注入到spring的IOC容器中。当定义的Feign中的接口被调用时,通过JDK的动态代理来生成RequestTemplate。
- RequestTemplate中包含请求的所有信息,如请求参数,请求URL等。
- RequestTemplate声名Request,然后将Request交给cl