专栏首页悟空聊架构 | 公众号18.SpringCloud实战项目-SpringCloud整合OpenFeign远程调用

18.SpringCloud实战项目-SpringCloud整合OpenFeign远程调用

1.Feign 概述

  • Feign声明式客的HTTP客户端,让远程调用更简单。
  • 提供了HTTP请求的模板,编写简单的接口和插入注解,就可以定义好HTTP请求的参数、格式、地址等信息
  • 整合了Ribbon(负载均衡组件)和Hystix(服务熔断组件),不需要显示使用这两个组件
  • Spring Cloud Feign 在Netflix Feign的基础上扩展了对SpringMVC注解的支持

2. 远程调用示例

示例:查询用户的学习时长

用户微服务passjava-member调用学习微服务passjava-study的方法

1.引入openfeign依赖

passjava-member和passjava-study项目的pom文件引入openfeign依赖

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>

2.StudyTimeController定义远程调用测试方法

返回某个用户学习题目的总时长

@RequestMapping("/member/list/test")
public R memberStudyTimeTest() {
    StudyTimeEntity studyTimeEntity = new StudyTimeEntity();
    studyTimeEntity.setTotalTime(100); // 学习时长:100分钟
    studyTimeEntity.setQuesTypeId(1L); // 题目类型:1 (javaBasic)

    return R.ok().put("studyTime", Arrays.asList(studyTimeEntity));
}

3.member目录下创建feign service

  • 创建package: com.jackson0714.passjava.member.feign
  • 创建StudyTimeFeignService接口
  • 添加注解@FeignClient。显示声明这个接口用来远程调用study服务。 @FeignClient("passjava-study") public interface StudyTimeFeignService {}
  • 添加远程调用方法 public R memberStudyTime();
  • 给方法添加要远程调用的方法的路径study/studytime/member/list/test @RequestMapping("study/studytime/member/list/test") public R getMemberStudyTimeListTest();
  • 添加注解@EnableFeignClients开启远程调用服务。 给类PassjavaStudyApplication.java添加注解@EnableFeignClients。 basePackages代表自动扫码指定路径下所有带有@FeignClient注解的接口。 @EnableFeignClients(basePackages = "com.jackson0714.passjava.member.feign") @EnableDiscoveryClient @MapperScan("com.jackson0714.passjava.member.dao") @SpringBootApplication public class PassjavaMemberApplication { public static void main(String[] args) { SpringApplication.run(PassjavaMemberApplication.class, args); } }
  • 测试接口
    • 启动passjava-member和passjava-study服务
    • 用postman工具或浏览器输入请求地址
    • 返回结果如下图

    studytime和member都有数据,学习时长:100分钟,昵称:悟空聊架构

4.测试OpenFeign传参

示例:用户id作为参数在服务间传递

MemberController

@RequestMapping("/studytime/list/test/{id}")
public R getMemberStudyTimeListTest(@PathVariable("id") Long id) {
    //mock数据库查到的会员信息
    MemberEntity memberEntity = new MemberEntity();
    memberEntity.setId(id); // 学习时长:100分钟
    memberEntity.setNickname("悟空聊架构");

    //远程调用拿到该用户的学习时长(学习时长是mock数据)
    R memberStudyTimeList = studyTimeFeignService.getMemberStudyTimeListTest(id);
    return R.ok().put("member", memberEntity).put("studytime", memberStudyTimeList.get("studytime"));
}

StudyTimeFeignService

@FeignClient("passjava-study")
public interface StudyTimeFeignService {
    @RequestMapping("study/studytime/member/list/test/{id}")
    public R getMemberStudyTimeListTest(@PathVariable("id") Long id);
}

StudyTimeController

@RequestMapping("/member/list/test/{id}")
public R memberStudyTimeTest(@PathVariable("id") Long id) {
    StudyTimeEntity studyTimeEntity = new StudyTimeEntity();
    studyTimeEntity.setTotalTime(100); // 学习时长:100分钟
    studyTimeEntity.setQuesTypeId(1L); // 题目类型:1 (javaBasic)

    return R.ok().put("studytime", Arrays.asList(studyTimeEntity));
}

执行结果:

3.总结FeignClient使用方法

  • 引入OpenFeign依赖
  • 定义FeignClient接口类(注解@FeignClient),声明这个接口类是用来远程调用其他服务的
  • 接口类中定义要远程调用的接口方法,指定远程服务方法的路径
  • Controller类中调用接口方法
  • 开启远程调用(注解@EnableFeignClients

代码地址

https://github.com/Jackson0714/PassJava-Platform

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 18.SpringCloud实战项目- 整合OpenFeign实现声明式远程调用

    用户微服务passjava-member调用学习微服务passjava-study的方法

    悟空聊架构
  • 09. SpringCloud实战项目-初始化项目和添加微服务

    悟空聊架构
  • 每天玩转3分钟 MyBatis-Plus - 6. select 用法

    代码下载:https://github.com/Jackson0714/study-mybatis-plus.git

    悟空聊架构
  • 18.SpringCloud实战项目- 整合OpenFeign实现声明式远程调用

    用户微服务passjava-member调用学习微服务passjava-study的方法

    悟空聊架构
  • 手把手教你做个生物无人机

    美国航空航天局(NASA)正在开发一种可以近距离探测火星的无人机原型。一定得是无人机成品被送入太空吗?非也非也。还有一种更酷的方法:将一小瓶细胞送上火星,让它自...

    机器人网
  • Spring MVC 学习总结(九)——Spring MVC实现RESTful与JSON(Spring MVC为前端提供服务)

     很多时候前端都需要调用后台服务实现交互功能,常见的数据交换格式多是JSON或XML,这里主要讲解Spring MVC为前端提供JSON格式的数据并实现与前台交...

    张果
  • [Go语言]一种用于网游服务器的支持多路复用的网络协议处理框架

    简介: 本文描述了使用Go语言实现的、适应于Go语言并发模型的一种支持多路复用的网络协议处理框架,并提供了框架的代码实现。作者将这种框架用于网络游戏服务器中的协...

    李海彬
  • [Go语言]一种用于网游服务器的支持多路复用的网络协议处理框架

    简介: 本文描述了使用Go语言实现的、适应于Go语言并发模型的一种支持多路复用的网络协议处理框架,并提供了框架的代码实现。作者将这种框架用于网络游戏服务器中的协...

    李海彬
  • SSH【史上最详细整合】

    最详细搭建SSH框架环境 本博文主要是讲解如何搭建一个比较规范的SSH开发环境,以及对它测试【在前面的搭建中,只是整合了SSH框架,能够使用SSH实现功能】,而...

    Java3y
  • Java IO 之 管道流 原理分析

    java404

扫码关注云+社区

领取腾讯云代金券