一起来学SpringCloud之整合Open Feign实现远程调用

请说下,一起来学SpringCloud之整合Open Feign实现远程调用
最新回答
姐独占天下

2024-12-03 02:47:36

前言

大家好,一直以来我都本着用最通俗的话理解核心的知识点, 我认为所有的难点都离不开 基础知识 的铺垫。目前正在出一个SpringCloud长期系列教程,从入门到进阶, 篇幅会较多~

适合人群

有一定的Java基础

想尝试微服务开发

有SpringBoot开发基础

想学习或了解SpringCloud

想提高自己的同学

大佬可以绕过 ~

背景

如果你是一路看过来的,很高兴你能够耐心看完。之前带大家学了Springboot这门框架,熟练掌握了单体应用的开发,如今微服务开发盛行,对我们的技术要求也是越来越高,薪资也是令人兴奋。这个系列将会带大家学习SpringCloud微服务开发,我会带大家一步一步的入门,耐心看完你一定会有收获~

情景回顾

上期带大家一起认识了ribbon以及带大家认识了常见的负载均衡策略,本期带着上期遗留下来的问题学习open feign,我们一起来看一下吧~

啥是Feign

Feign集成了Ribbon、RestTemplate实现了负载均衡的执行Http调用,只不过对原有的方式(Ribbon+RestTemplate)进行了封装,开发者不必手动使用RestTemplate调服务,而是定义一个接口,在这个接口中标注一个注解即可完成服务调用,这样更加符合面向接口编程的宗旨,简化了开发。

那么feign 和 open feign有啥关系呢?没错,open feign是spring cloud大家族的一员。feign已经停止维护迭代了, OpenFeign是springcloud在Feign的基础上支持了SpringMVC的注解, 如@RequestMapping `

集成Open Feign

为了方便测试,我们依然新建一个模块, 大家自行创建,我们需要多引入一个依赖:

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

启动类上需要加上 @EnableFeignClients

@EnableFeignClients(basePackages = "com.cloud.openfeign.api")@SpringCloudApplicationpublic class OpenFeignApplicaiton {public static void main(String[] args) {SpringApplication.run(OpenFeignApplicaiton.class, args);}}

我们说原来的调用方式通过restTemplate,在这里我们需要改成通过feign来获取了, 新建接口

api.OpenFeignService

@FeignClient(value = "provider")public interface OpenFeignService {}

value对应我们之前写的服务提供者, 测试的时候依然需要开启它, 那怎么去调用服务呢,很简单:

@FeignClient(value = "provider")public interface OpenFeignService {// post请求@PostMapping("/openfeign/provider/order2")User getUser(@RequestBody User user);}

下面我们来测下

@RequestMapping("/hello/user/{id:\\d+}")@ResponseBodypublic User hello(@PathVariable String id) {User user = new User();user.setUsername(id);return openFeignService.getUser(user);}

因为它集成了 SpringMvc注解,所以用起来很方便

超时设置

超时设置还是比较重要的,前几节也都给大家讲过, 这里推荐大家使用feign配置

feign:client:config:#default 设置的全局超时时间default:connectTimeout: 5000readTimeout: 5000# 指定服务provider:connectTimeout: 30000readTimeout: 30000

结束语

本期到这里就结束了, 总结一下,本节主要讲了OpenFeign, 以及项目集成, 带大家简单实现了一个服务调用, 其实它还有一些很好用的方法,就不一一带大家尝试了,留给大家自己去实践,用法都差不多, 建议大家自己多去尝试 ~

下期预告

之前给大家介绍了服务熔断和服务降级组件hystrix, 当服务面对大流量的冲击的时候, 通常我们会采取一些保护手段,保护服务的正常运行, 也可以防护一些恶意接口调用,下期,给大家讲一下限流框架神器Sentinel, 同样的,它也是阿里巴巴开源,我们把它集成到项目中。 关注我,不迷路, 下期不见不散 ~

更文时间

工作日(周一 ? 周五)

周末不更 ??

节假日不定时更

往期内容

我的博客(阅读体验较佳)

SpringBoot系列教程合集

一起来学SpringCloud之微服务概述

一起来学SpringCloud之整合Nacos

一起来学SpringCloud之服务间调用

一起来学SpringCloud之整合hystrix服务熔断和降级

一起来学SpringCloud之整合Ribbon

项目源码(源码已更新 欢迎star??)

springboot-all

地址: https://github.com/qiuChengleiy/springboot-all.git

原文:https://juejin.cn/post/7098167927190323207