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

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

微信截图_20230209163713.png


前言

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


适合人群

  • 有一定的Java基础
  • 想尝试微服务开发
  • 有SpringBoot开发基础
  • 想学习或了解SpringCloud
  • 想提高自己的同学

大佬可以绕过 ~


背景

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


情景回顾

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


啥是Feign

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


那么feignopen feign有啥关系呢?没错,open feignspring 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")
@SpringCloudApplication
public 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+}")
    @ResponseBody
    public User hello(@PathVariable String id) {
        User user = new User();
        user.setUsername(id);
        return openFeignService.getUser(user);
    }
复制代码

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


超时设置

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

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


结束语

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


下期预告

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

相关文章
|
3月前
|
监控 Java API
Spring Boot 3.2 结合 Spring Cloud 微服务架构实操指南 现代分布式应用系统构建实战教程
Spring Boot 3.2 + Spring Cloud 2023.0 微服务架构实践摘要 本文基于Spring Boot 3.2.5和Spring Cloud 2023.0.1最新稳定版本,演示现代微服务架构的构建过程。主要内容包括: 技术栈选择:采用Spring Cloud Netflix Eureka 4.1.0作为服务注册中心,Resilience4j 2.1.0替代Hystrix实现熔断机制,配合OpenFeign和Gateway等组件。 核心实操步骤: 搭建Eureka注册中心服务 构建商品
674 3
|
1月前
|
负载均衡 Java API
《深入理解Spring》Spring Cloud 构建分布式系统的微服务全家桶
Spring Cloud为微服务架构提供一站式解决方案,涵盖服务注册、配置管理、负载均衡、熔断限流等核心功能,助力开发者构建高可用、易扩展的分布式系统,并持续向云原生演进。
|
7月前
|
Java 开发者 微服务
Spring Cloud OpenFeign详解与实践
总结起来说,Spring Cloud OpenFeign提供了一种简单易懂且高效的方式去实现微服务之间通信.它隐藏了许多复杂性,并且允许开发者以声明式方式编写HTTP客户端代码.如果你正在开发基于Spring Cloud 的微服务架构系统,Spring Cloud Open Feign是一个非常好用且强大工具.
519 33
|
7月前
|
负载均衡 前端开发 Java
SpringCloud调用组件Feign
本文深入探讨微服务Spring体系中的Feign组件。Feign是一个声明式Web服务客户端,支持注解、编码器/解码器,与Spring MVC注解兼容,并集成Eureka、负载均衡等功能。文章详细介绍了SpringCloud整合Feign的步骤,包括依赖引入、客户端启用、接口创建及调用示例。同时,还涵盖了Feign的核心配置,如超时设置、拦截器实现(Basic认证与自定义)和日志级别调整。最后,总结了`@FeignClient`常用属性,帮助开发者更好地理解和使用Feign进行微服务间通信。
649 1
|
8月前
|
负载均衡 Dubbo Java
Spring Cloud Alibaba与Spring Cloud区别和联系?
Spring Cloud Alibaba与Spring Cloud区别和联系?
|
9月前
|
前端开发 Java Nacos
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
本文介绍了如何使用Spring Cloud Alibaba 2023.0.0.0技术栈构建微服务网关,以应对微服务架构中流量治理与安全管控的复杂性。通过一个包含鉴权服务、文件服务和主服务的项目,详细讲解了网关的整合与功能开发。首先,通过统一路由配置,将所有请求集中到网关进行管理;其次,实现了限流防刷功能,防止恶意刷接口;最后,添加了登录鉴权机制,确保用户身份验证。整个过程结合Nacos注册中心,确保服务注册与配置管理的高效性。通过这些实践,帮助开发者更好地理解和应用微服务网关。
1696 0
🛡️Spring Boot 3 整合 Spring Cloud Gateway 工程实践
|
10月前
|
人工智能 安全 Java
AI 时代:从 Spring Cloud Alibaba 到 Spring AI Alibaba
本次分享由阿里云智能集团云原生微服务技术负责人李艳林主讲,主题为“AI时代:从Spring Cloud Alibaba到Spring AI Alibaba”。内容涵盖应用架构演进、AI agent框架发展趋势及Spring AI Alibaba的重磅发布。分享介绍了AI原生架构与传统架构的融合,强调了API优先、事件驱动和AI运维的重要性。同时,详细解析了Spring AI Alibaba的三层抽象设计,包括模型支持、工作流智能体编排及生产可用性构建能力,确保安全合规、高效部署与可观测性。最后,结合实际案例展示了如何利用私域数据优化AI应用,提升业务价值。
977 4
|
11月前
|
负载均衡 Java 开发者
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
深入探索Spring Cloud与Spring Boot:构建微服务架构的实践经验
666 5
|
负载均衡 Java Nacos
SpringCloud基础2——Nacos配置、Feign、Gateway
nacos配置管理、Feign远程调用、Gateway服务网关
SpringCloud基础2——Nacos配置、Feign、Gateway
下一篇
oss云网关配置