(三)OpenFeign

基础使用

使用步骤

  1. 引入jar包
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>                           
  1. 开启注解
@SpringBootApplication
@EnableEurekaClient
@EnableFeignClients
public class SpringCloudProviderCosumerApplication {

    public static void main(String[] args) {
        SpringApplication.run(SpringCloudProviderCosumerApplication.class, args);
    }

}
  1. 提供Service接口描述。

这里可以在客户端单独提供一个API进行描述,客户端可以直接引入,无需再定义。服务端也同样引入,直接实现即可。

@FeignClient("spring-cloud-ribbon-service")
public interface OpenFeignTestService {

    @GetMapping("/test")
    String OpenFeignTest();
}

OpenFeign底层也是通过http请求实现。

该接口其实就是为了描述http请求所需要的全部条件。如:服务名称(地址)、请求方式、请求方法、请求参数、返回类型...等

  1. 调用示例
@RestController
public class OpenFeignTestController {

    @Autowired
    OpenFeignTestService openFeignTestService;

    @GetMapping("/openFeignTest")
    public String openFeignTest(){
        return openFeignTestService.OpenFeignTest();
    }

}

请求、响应压缩

在远程调用请求、响应数据较大的情况下可以配置使用GZIP压缩。(默认2048字符以上)

#配置请求GZIP压缩
feign.compression.request.enabled=true
#配置响应GZIP压缩
feign.compression.response.enabled=true
# 配置压缩数据大小限制 (字符)
feign.compression.request.min-request-size=2048

日志级别控制

可以针对某些Feign接口指定日志跟踪。

  1. 新增配置
logging.level.[com.fishbone.example.springcloudprovidercosumer.OpenFeignTestService] = debug
  1. 注册Bean
@Configuration
public class FishBoneFeignLogLevel {

    @Bean
    Logger.Level feignLogLevel(){
        return Logger.Level.FULL;
    }

}
  1. 绑定配置类(增加configuration)
@FeignClient(value = "spring-cloud-ribbon-service",configuration = FishBoneFeignLogLevel.class)
public interface OpenFeignTestService {

    @GetMapping("/test")
    String OpenFeignTest();
}

替换底层通讯方式

修改配置关闭httpclient,开启okhttp

feign.httpclient.enabled=false
feign.okhttp.enabled=true

引入okhttp jar

 <dependency>
      <groupId>io.github.openfeign</groupId>
      <artifactId>feign-okhttp</artifactId>
      <version>10.2.0</version>
 </dependency>      

OpenFeign原理

  1. 动态代理注入。
    • 注入结果通过Spring的哪个扩展点实现?与Mybatis的扩展行为是否类似?
      • Mybatis动态代理主要通过,SqlSessionFactory的初始化(实现了InitializingBean),将扫描需要生成代理的对象Mapper生成BeanDefinition注册到SpringIOC容器,方便Service层引入(主要通过Mybatis配置来确认需要扫描路径)
  2. 代理类可以从接口维度,统一进行解析存储。
  3. 发起请求时需要进行LoadBlance。

OpenFeign可以看做是一个模板。比如下方示例。定义了请求方式,包括。服务名称(host)、请求路径、GET/POST、参数、结果,这些已经可以满足我们进行http请求调用。OpenFeign客户端便是通过这些,生成代理对象,从而在调用时向服务端发起请求。

代理对象中主要通过对注解进行解析,从Eureka中获取服务列表,再利用LoadBlance进行负载均衡,最后向服务端请求数据结果。

public interface IGoodsService {

    @GetMapping("/getGoods")  // 请求路径
    String getGoodsInfo(@RequestParam("id") int goodsId);
}

@FeignClient(name = "spring-cloud-service-goods")  // 服务名称
public interface IGoodsServiceFeignClient extends IGoodsService {

}

问题思考

OpenFeign 优点

OpenFeign方便了跨服务之间的调用。如果没有OpenFeign我们要知道具体的地址才可以发起http请求获得返回结果。

如何与Ribbon配合实现跨服务调用?

底层是采用什么通讯方式?与RestTemplate区别在哪里?

底层使用Http通讯方式。RestTemplate是对Http协议的一种封装。

OpenFeign 为什么要抽离一个接口Module?

  1. 首先,接口是需要提供给服务端做实现,给客户端做调用,为了方便两者使用, 直接抽离出一个Module可以使客户端引入更轻量(只包含接口定义),也可以使服务端无需向服务端提供一些单独的接口说明。

  2. 其次,直接引入jar包方式更加的透明,有改动服务端便可感知,避免不一致错误。

客户单不引入服务端jar包,直接手写接口是否可以?

不引入服务端jar包自己写接口也完全可以。
只要定义好FeignClient模板,交给Feingn去扫描加载,都可以请求到服务端。服务端直接提供jar包的方式是一种接口的收敛,方便客户端调用,有变动仅需要修改服务端版本即可。比如,服务端A提供了接口IA,同时被服务B/C/D使用,如果不引入jar包由客户端B/C/D自行定义,容易出错,且服务A修改需要增加参数时,B/C/D必需要修改。

思考,如果服务A 1.0版本接口 IA 只有一个参数 id,B服务引入了该版本服务接口。 然后服务A 升级版本,1.1 ,接口IA 增加参数 name,此时,服务 B 继续使用1.0版本接口IA,请求时是否会出现问题?取决于什么?为什么?

接口为什么要加@GetMaping、@FeignClient注解?

OpenFeign 怎么与Spring 结合 达到扫描其自定义注解 @FeignClient 的功能?

OpenFeign 中大量使用了 动态代理,实际开发中是否可以借鉴?

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,204评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,091评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,548评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,657评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,689评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,554评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,302评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,216评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,661评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,851评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,977评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,697评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,306评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,898评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,019评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,138评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,927评论 2 355

推荐阅读更多精彩内容