服务调用方式

微服务或者SOA都会面临服务间的远程调用, 服务间的远程调用有2种方式:
 
  • 1. RPC
Remote Produce Call 远程过程调用,自定义数据格式,基于原生TCP通信,速度快、效率高。
 
WebService, Dubbo都是RPC的代表。
 
  • 2. HTTP
HTTP是一种网络传输协议,基于TCP,规定数据传输的格式。
  • 优点:对服务的提供和调用方没有技术限定,更符合微服务理念
  • 缺点:消息封装臃肿
应用场景
  • Dubbo: 公司全部采用Java技术栈
  • Spring Cloud:技术栈多样化(多种语言开发),更青睐Spring。(证券公司的服务器用C编写)
HTTP客户端工具
  • HttpClient
  • OKHttp
  • HttpUrlConnection
客户端工具不同,API也不同。
 
Spring ResetTemplate
 
Spring提供ResetTemplate模板工具类,对基于http的客户端进行封装。实现对象与json的序列化和反序列化,非常方便。
 
ResetTemplate没有限定http客户端类型,支持三种客户端。
  • HttpClient
  • OKHttp
  • JDK原生的HttpUrlConnection(默认)
 
 
Feign是一个声明式的Web服务客户端,它使得编写Web服务客户端变得更加简单。通过使用Feign,我们可以以类似于编写控制器的方式调用远程服务。 在使用Feign进行服务调用时,我们需要按照以下步骤进行: 1. 导入Feign依赖:在项目的pom.xml文件中添加Feign的依赖,例如: ```xml <dependency> <groupId>org.springframework.cloud</groupId> <artifactId>spring-cloud-starter-openfeign</artifactId> </dependency> ``` 2. 启用Feign:在主应用程序类上添加`@EnableFeignClients`注解,例如: ```java @SpringBootApplication @EnableFeignClients public class MyApp { public static void main(String[] args) { SpringApplication.run(MyApp.class, args); } } ``` 3. 创建Feign客户端接口:定义一个接口,使用`@FeignClient`注解指定要调用的目标服务名称,例如: ```java @FeignClient(name = "target-service") public interface TargetServiceClient { @GetMapping("/api/resource") ResponseEntity<Resource> getResource(); } ``` 4. 调用远程服务:在需要调用远程服务的地方,通过自动注入方式注入Feign客户端接口,并直接调用其中的方法,例如: ```java @RestController public class MyController { private final TargetServiceClient targetServiceClient; public MyController(TargetServiceClient targetServiceClient) { this.targetServiceClient = targetServiceClient; } @GetMapping("/my-endpoint") public ResponseEntity<Resource> myEndpoint() { return targetServiceClient.getResource(); } } ``` 通过上述步骤,我们可以使用Feign来简化服务间的调用,并且可以像调用本地方法一样调用远程服务
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值