当前播放: 93 | 使用Feign访问服务
00:00 / 00:00
高清
  • 高清
1.0x
  • 2.0x
  • 1.5x
  • 1.25x
  • 1.0x
  • 0.5x
网页全屏
全屏
00:00
付费课程,可试看
课程目录
第一章:初识Spring (4讲)
01 | Spring课程介绍
免费
02 | 一起认识Spring家族的主要成员
免费
03 | 跟着Spring了解技术趋势
免费
04 | 编写你的第一个Spring程序
免费
第二章:JDBC必知必会 (10讲)
05 | 如何配置单数据源
免费
06 | 如何配置多数据源
免费
07 | 那些好用的连接池们:HikariCP
08 | 那些好用的连接池们:Alibaba Druid
09 | 如何通过Spring JDBC访问数据库
10 | 什么是Spring的事务抽象(上)
11 | 什么是Spring的事务抽象(下)
12 | 了解Spring的JDBC异常抽象
免费
13 | 课程答疑(上)
14 | 课程答疑(下)
第三章:O/R Mapping实践 (9讲)
15 | 认识Spring Data JPA
16 | 定义JPA的实体对象
17 | 开始我们的线上咖啡馆实战项目:SpringBucks
18 | 通过Spring Data JPA操作数据库
19 | Spring Data JPA的Repository是怎么从接口变成Bean的
20 | 通过MyBatis操作数据库
21 | 让MyBatis更好用的那些工具:MyBatis Generator
22 | 让MyBatis更好用的那些工具:MyBatis PageHelper
23 | SpringBucks实战项目进度小结
第四章:NoSQL实践 (7讲)
24 | 通过Docker辅助开发
25 | 在Spring中访问MongoDB
26 | 在Spring中访问Redis
27 | Redis的哨兵与集群模式
28 | 了解Spring的缓存抽象
29 | Redis在Spring中的其他用法
30 | SpringBucks实战项目进度小结
第五章:数据访问进阶 (8讲)
31 | Project Reactor介绍(上)
32 | Project Reactor介绍(下)
33 | 通过Reactive的方式访问Redis
34 | 通过Reactive的方式访问MongoDB
35 | 通过Reactive的方式访问RDBMS
36 | 通过AOP打印数据访问层的摘要(上)
37 | 通过AOP打印数据访问层的摘要(下)
38 | SpringBucks实战项目进度小结
第六章:Spring MVC实践 (14讲)
39 | 编写第一个Spring MVC Controller
40 | 理解Spring的应用上下文
41 | 理解请求的处理机制
42 | 如何定义处理方法(上)
43 | 如何定义处理方法(下)
44 | Spring MVC中的视图解析机制(上)
45 | Spring MVC中的视图解析机制(下)
46 | Spring MVC中的常用视图(上)
47 | Spring MVC中的常用视图(下)
48 | 静态资源与缓存
49 | Spring MVC中的异常处理机制
50 | 了解Spring MVC的切入点
51 | SpringBucks实战项目进度小结
52 | 课程答疑
第七章:访问Web资源 (5讲)
53 | 通过RestTemplate访问Web资源
54 | RestTemplate的高阶用法
55 | 简单定制RestTemplate
56 | 通过WebClient访问Web资源
57 | SpringBucks实战项目进度小结
第八章: Web开发进阶 (9讲)
58 | 设计好的RESTful Web Service(上)
59 | 设计好的RESTful Web Service(下)
60 | 什么是HATEOAS
61 | 使用Spring Data REST实现简单的超媒体服务(上)
62 | 使用Spring Data REST实现简单的超媒体服务(下)
63 | 分布式环境中如何解决Session的问题
64 | 使用WebFlux代替Spring MVC(上)
65 | 使用WebFlux代替Spring MVC(下)
66 | SpringBucks实战项目进度小结
第九章:重新认识Spring Boot (8讲)
67 | 认识Spring Boot的组成部分
68 | 了解自动配置的实现原理
69 | 动手实现自己的自动配置
70 | 如何在低版本Spring中快速实现类似自动配置的功能
71 | 了解起步依赖及其实现原理
72 | 定制自己的起步依赖
73 | 深挖Spring Boot的配置加载机制
74 | 理解配置背后的PropertySource抽象
第十章:运行中的Spring Boot (11讲)
75 | 认识Spring Boot的各类Actuator Endpoint
76 | 动手定制自己的Health Indicator
77 | 通过Micrometer获取运行数据
78 | 通过Spring Boot Admin了解程序的运行状态
79 | 如何定制Web容器的运行参数
80 | 如何配置容器支持HTTP/2(上)
81 | 如何配置容器支持HTTP/2(下)
82 | 如何编写命令行运行的程序
83 | 了解可执行Jar背后的秘密
84 | 如何将Spring Boot应用打包成Docker镜像文件
85 | SpringBucks实战项目进度小结
第十一章:Spring Cloud及Cloud Native概述 (5讲)
86 | 简单理解微服务
87 | 如何理解云原生(Cloud Native)
88 | 12-Factor App(上)
89 | 12-Factor App(下)
90 | 认识Spring Cloud的组成部分
第十二章:服务注册与发现 (9讲)
91 | 使用Eureka作为服务注册中心
92 | 使用Spring Cloud Loadbalancer访问服务
93 | 使用Feign访问服务
94 | 深入理解服务发现背后的DiscoveryClient
95 | 使用Zookeeper作为服务注册中心
96 | 使用Consul作为服务注册中心
97 | 使用Nacos作为服务注册中心
98 | 如何定制自己的DiscoveryClient
99 | SpringBucks实战项目进度小结
第十三章:服务熔断 (7讲)
100 | 使用Hystrix实现服务熔断(上)
101 | 使用Hystrix实现服务熔断(下)
102 | 如何观察服务熔断
103 | 使用Resilience4j实现服务熔断
104 | 使用Resilience4j实现服务限流(上)
105 | 使用Resilience4j实现服务限流(下)
106 | SpringBucks实战项目进度小结
第十四章:服务配置 (7讲)
107 | 基于Git的配置中心(上)
108 | 基于Git的配置中心(下)
109 | 基于Zookeeper的配置中心
110 | 深入理解Spring Cloud的配置抽象
111 | 基于Consul的配置中心
112 | 基于Nacos的配置中心
113 | SpringBucks实战项目进度小结
第十五章:Spring Cloud Stream (4讲)
114 | 认识Spring Cloud Stream
115 | 通过Spring Cloud Stream访问RabbitMQ
116 | 通过Spring Cloud Stream访问Kafka
117 | SpringBucks实战项目进度小结
第十六章:服务链路追踪 (6讲)
118 | 通过Dapper理解链路治理
119 | 使用Spring Cloud Sleuth实现链路追踪
120 | 如何追踪消息链路
121 | 除了链路还要治理什么
122 | SpringBucks实战项目进度小结
123 | 结课测试&结束语
93 | 使用Feign访问服务

93 | 使用Feign访问服务

丁雪丰
平安壹钱包高级架构师,《Spring Boot实战》《Spring攻略》译者,InfoQ社区编辑
全集30443
新人首单 ¥29.9 原价 ¥129
5
登录 后留言

精选留言(18)

  • StopLiu
    老师,遇到个问题搞了很久都搞不定,通过feign获取不到http的header怎么办?

    作者回复: 网上还是有不少类似的问题解决方案的,可以搜索一下“Feign 获取 Header”,比如,在其中大部分都会提到要修改一下hystrix.command.default.execution.isolation.strategy=SEMAPHORE ,你可以试试。

    2020-01-02
    1
    3
  • William
    赞.
           之前一直没找到解决同一个服务提供2个同名client的方法(可能找的方法不对,就找博客了).
          现在知道了可以在@FeignClient中 加入contextId进行区分.


    请问老师,有哪些渠道可以解决遇到问题不知道去哪里找解决方案的方式呢?


    作者回复: 建议用Google,一般会找到Github或者Stackoverflow上,国内的也有一些网站,用对关键字比较重要。

    2020-01-12
    1
  • 看山
    服务端支持xml和json两种格式,默认xml,想要返回json需要指定请求头content-type是application/json才行,直接用feign总是提示解码失败,需要怎么配置呢?

    作者回复: @PostMapping(path = "/", consumes = MediaType.APPLICATION_JSON_VALUE,
                produces = MediaType.APPLICATION_JSON_UTF8_VALUE)
    在方法上用这样的形式可以限定接收和返回的类型,都是JSON。

    2019-11-10
    1
  • ∫1/(x^4*√(1+x^2)...
    我在使用feign做文件上传的操作,查询了网上各种解决办法,依然会有报错:请求的类型不是多媒体类型,无法解析,自定义了多媒体转换器不起作用,不知道feign在做文件上传的时候,标准的做法是怎样的

    作者回复: 建议可以看看程序猿DD或者周立的博客,对Feign上传文件都有示例,比如http://blog.didispace.com/spring-cloud-starter-dalston-2-4/和http://www.itmuch.com/spring-cloud-sum/spring-cloud-feign-upload/

    2019-11-07
    1
  • 国境之南
    @FeignClient(name = "waiter-service", contextId = "coffee", path = "/coffee")
    // 不要在接口上加@RequestMapping
    public interface CoffeeService {
        @GetMapping(path = "/", params = "!name")
        List<Coffee> getAll();

        @GetMapping("/{id}")
        Coffee getById(@PathVariable("id") Long id);

        @GetMapping(path = "/", params = "name")
        Coffee getByName(@RequestParam("name") String name);
    }
    PathVariable RequestParam 两个后面不加对应的参数名称 (“id”)("name")
    启动customer 会报错
    这是为什么呢?

    作者回复: 能把详细的报错提供一下么?很长的话可以贴在Github的gist里,把URL贴留言里

    2019-05-15
    5
    1
  • 大妖怪😀
    老师:
         我在运行案例CustomerService的时候报错。报错信息如下:
    org.springframework.beans.factory.UnsatisfiedDependencyException: Error creating bean with name 'customerRunner': Unsatisfied dependency expressed through field 'coffeeService'; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'geektime.spring.springbucks.customer.integration.CoffeeService': FactoryBean threw exception on object creation; nested exception is java.lang.IllegalStateException: RequestParam.value() was empty on parameter 0
      我百度了一下,发现只要注销下面两个方法就可以。
    @GetMapping("/{id}")
        Coffee getById(@PathVariable Long id);

    @GetMapping(path = "/", params = "name")
    Coffee getByName(@RequestParam String name);

    然后我进一步试验,发现getById方法@PathVariable加一个("id"),程序也不会报错
    @GetMapping("/{id}")
        Coffee getById(@PathVariable("id") Long id);

    但是
    @GetMapping(path = "/", params = "name")
        Coffee getByName(@RequestParam String name);
    写法还是会让我的程序报错。为什么呢?

    作者回复: 如果可以,你能否把你报错的完整工程上传到Gitee或者Github上呢?

    2020-04-01
  • Edon du
    Feign 和 gRPC 如何选型。如果用了Feign后期改造gRPC 坑点多不多。

    作者回复: 这个我没有实际这么操作过,不能给你太多的建议,不过从过往全站系统升级的经历中来看,这个底层调用方式的更迭,都不会一帆风顺的,各种意想不到的地方会出问题。如果可以,还是尽量在前期做好决定,短期内就不用折腾了。

    2020-02-29
  • 大力水手
    请问一下,openfeign能跟webflux优雅的结合起来使用么?

    作者回复: webflux的服务发不出来就和普通的web服务是一样的,所以可以用feign去调用这些服务。不过一般情况下feign的调用是同步的,不像webclient这样调用是异步的,网上有基于webclient写的非同步的feign,可以了解一下。

    2020-01-16
  • 大力水手
    feign跟webflux能优雅的结合么?
    2020-01-16
  • 龙雀。
    请问下老师,我的feign项目打成jar包在别的项目引入,那个项目启动时会有BeanPostProcessor的误伤,报错为 xxx is not eligible for getting processed by all BeanPostProcessors (for example: not eligible for auto-proxying),请问怎么解决啊?

    作者回复: 这个是说某些Bean可能没有被所有BeanPostProcessor处理,因此有些增强逻辑可能就没有。这个情况会比较多,比如,有些是提前初始化了某个Bean,还是得仔细检查下启动顺序,分析后才能知道是哪些Bean影响了。

    2020-01-15
  • longslee
    老师,我今天在用 Feign 透传 HttpServletRequest 的时候,报了Jackson转换错误,调用方接受了一个HttpServletRequest req,将这个 req 透传给提供方,结果是不行,百思不得其解。

    作者回复: 应该是序列化相关的问题,可以拿对应的报错信息去搜索一下。但我不明白的是为什么一定要透传一个HttpServletRequest过去?一定要搞,实在不行的话,把这个Request变成你自己的一个类型,先序列化成JSON的String,传过去后自己再把它反序列化出来总可以吧。这算是个绕过的方法吧,但是有点麻烦。

    2019-12-23
  • Ken
    老师我想问,
    1)fegin里面 okhttp跟httpclient的应用场景如何判断;
    2)fegin实际开发的时候,service端相关响应类如何管理的啊?譬如service-1返回一个对象Book,那么client端如何获取这个Book.java的文件,这些如何管理?

    作者回复: 1. 两个框架都不错,用哪个都可以,但如果你要用HTTP/2,OkHttp大概是目前你唯一的选择,HttpClient的5.0里才支持。
    2. 如果想完全按照教科书来,REST服务应该是解耦的,你在客户端重新定义一个Book,能反序列化出来就好。但如果服务的提供方和消费方都是Java的,偷懒一点的做法可以把接口和类打成JAR提供出来。但是,要注意兼容性,别接口一升级就逼着别人跟着你升JAR。

    2019-11-16
  • 行下一首歌
    使用feign调用,返回参数是直接就是个dto,还是说也要包一层,就像输出给前端的数据。

    作者回复: Feign就是远程调用了,针对远程调用,你觉得是不是应该有一定的封装呢?如果内容很简单,你也可以直接拿个对象来用。这个就是你自己把握啦。

    2019-07-23
  • Peterb
    feign 和 loadbalance resttemplate 的区别是什么

    作者回复: 本质都是做了远程调用,只是使用的方式不同而已

    2019-07-22
  • Peterb
    feign 和 loadbalance resttemplate 的区别是什么
    2019-07-22
  • 🇯 🇮 🇱 🇮 🇳 ...
    我eureka-server已经启动,
    但是启动waiter-service报这个错,注册不了,怎么回事?

    com.ecwid.consul.transport.TransportException: org.apache.http.conn.HttpHostConnectException: Connect to localhost:8500 [localhost/127.0.0.1, localhost/0:0:0:0:0:0:0:1] failed: Connection refused: connect

    作者回复: 你到底是用的Eureka还是Consul呢,你说的是启动Eureka,但报错是Consul的哦

    2019-06-24
  • rivers
    springcloud的服务调用的负载均衡如何做的呢,老师会讲吗

    作者回复: 第94讲就是和这个相关的内容。

    2019-06-23
  • 王堃
    feign接受requestbody的json格式吗

    作者回复: 支持呀,我们的接口不都是JSON的么

    2019-06-20
收起评论
看过的人还看
Java核心技术面试精讲

杨晓峰  前Oracle首席工程师

44讲 | 47113 人已学习

新人首单 ¥19.9 原价 ¥99
数据结构与算法之美

王争  前Google工程师

80讲 | 88921 人已学习

新人首单 ¥29.9 原价 ¥129
MySQL实战45讲

林晓斌  网名丁奇,前阿里资深技术专家

49讲 | 57756 人已学习

新人首单 ¥29.9 原价 ¥129
Java并发编程实战

王宝令  资深架构师

51讲 | 18244 人已学习

新人首单 ¥19.9 原价 ¥99