使用OpenFeign实现HTTP调用的最简单案例

  1. 首先编写服务提供者代码,也就是创建一个springboot项目,端口默认8080即可,然后新建一个接口,启动项目之后可以通过http://localhost:8080/api/data直接访问
java 复制代码
@RestController
@RequestMapping("/api")
public class DataController {

    @GetMapping("/data")
    public String getData() {
        return "Hello from Producer!";
    }
}
  1. 然后编写服务消费者代码,端口设置为8081,启动类加@EnableFeignClients,访问http://localhost:8081/consumer/data依旧可以返回结果
java 复制代码
@FeignClient(name = "producer", url = "http://localhost:8080")
public interface ProducerClient {

    @GetMapping("/api/data")
    String getData();
}
java 复制代码
@RestController
@RequestMapping("/consumer")
public class ConsumerController {

    @Autowired
    private ProducerClient producerClient;

    @GetMapping("/data")
    public String getDataFromProducer() {
        return producerClient.getData();
    }
}
  1. 总结
  • 在这个案例中,是基于 HTTP 的调用,而不是传统的 RPC 调用。这里使用了 OpenFeign 来简化 HTTP 客户端的开发,通过定义接口 ProducerClient 并使用注解 @FeignClient 指定了目标服务的 URL 和接口路径,OpenFeign 会自动生成实现这个接口的 HTTP 客户端,从而让你能够像调用本地方法一样调用远程服务。

  • 具体来说,在你的例子中,ConsumerController 中的 getDataFromProducer 方法调用了 ProducerClient 接口的 getData 方法。这看起来就像是直接调用了远程服务的一个方法,但实际上,ProducerClient 是由 OpenFeign 动态生成的一个代理对象,该对象内部实现了向 http://localhost:8080/api/data 发起 HTTP GET 请求的功能,并将响应结果转换成 String 类型返回给调用者。

  • 因此,尽管从代码的角度看,调用过程类似于 RPC 调用,但实际上,这仍然是基于 HTTP 协议的 RESTful API 调用。OpenFeign 只是提供了一种更简洁的方式来处理这些 HTTP 请求,使代码更加清晰易读,减少了手动构建 HTTP 请求和解析响应的工作量。

相关推荐
古城小栈24 分钟前
Rust 网络请求库:reqwest
开发语言·网络·rust
qq_316837754 小时前
IP网段冲突 配置指定ip使用指定的网络接口发送,而不经过默认网关
服务器·网络·tcp/ip
布史4 小时前
Tailscale虚拟私有网络指南
linux·网络
枷锁—sha5 小时前
彻底解决 Google Gemini 报错:异常流量与 IP 地址冲突排查指南
网络·网络协议·tcp/ip
Xの哲學5 小时前
深入剖析Linux文件系统数据结构实现机制
linux·运维·网络·数据结构·算法
_风华ts5 小时前
虚幻引擎RPC
rpc·游戏引擎·虚幻
-To be number.wan5 小时前
经典真题精讲|2010年408统考第34题:文件传输最少需要多久?
网络·计算机网络
逐梦苍穹5 小时前
不用公网 IP,把内网服务安全发布到公网:ZeroNews 快速上手
网络协议·tcp/ip·安全·内网穿透
知乎的哥廷根数学学派6 小时前
基于多尺度注意力机制融合连续小波变换与原型网络的滚动轴承小样本故障诊断方法(Pytorch)
网络·人工智能·pytorch·python·深度学习·算法·机器学习
好多渔鱼好多7 小时前
【流媒体协议】RTSP / RTP / RTCP 协议全景介绍
网络·网络协议·rtp·rtsp·rtcp·ipc摄像头