SpringBoot-什么是RPC

什么是RPC ?

     RPC【Remote Proceduce Call】是指远程过程调用,是一种进程间的通信方式,他是一种技术的思想,而不是规范。它允许程序调用另一个地址空间(通常是共享网络的另一台机器上)的过程或函数,而不是程序员显式编码这个远程调用的细节。即程序员无论是调用本地的还是远程的函数,本质上编写的调用代码基本相同。

    也就是说两台服务器A,B;一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在同一个内在空间,不能直接调用,需要通过网络来表达调用的语义和传达调用的数据。为什么要用RPC呢?就是无论在一个进程内,甚至一个计算机内通过本地调用的方式完成的需求,比如不同系统间的通讯,甚至不同的组织间的通讯,由于计算能力需要横向扩展,需要在多台机器组成的集群上部署应用。RPC就是要像调用本地的函数一样去调远程函数。

PRC基本原理如下图:

解读:

 

两个核心模块:通讯,序列化

 

Spring Boot 整合 Nacos 通常是为了实现服务发现和配置管理的功能,特别是当涉及到微服务架构中的 RPC (Remote Procedure Call) 服务通信时,Nacos 的服务注册与发现功能非常有用。以下是集成的基本步骤: 1. 添加依赖:在你的 Maven 或 Gradle 项目中添加 Spring Cloud 的 Alibaba 开源组件依赖,如 ribbon、spring-cloud-alibaba-nacos-discovery 等。 ```xml <!-- Maven --> <dependency> <groupId>com.alibaba.cloud</groupId> <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </dependency> <!-- Gradle --> implementation 'com.alibaba.cloud:spring-cloud-starter-alibaba-nacos-discovery' ``` 2. 配置 Nacos:在 application.properties 或 application.yml 文件中加入 Nacos 的地址、命名空间以及服务的注册信息。 ```properties spring.application.name=your-service-name spring.cloud.nacos.discovery.server-addr=nacos-server-url spring.cloud.nacos.discovery.namespace=your-namespace ``` 3. 使用 @EnableDiscoveryClient 注解启用服务发现:在你的主入口类上添加此注解,Spring Boot 将自动发现并注册到 Nacos 中。 ```java @SpringBootApplication @EnableDiscoveryClient public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } ``` 4. RPC 服务发现:对于RPC服务,比如Dubbo或者RSocket,需要配合其他模块如Spring Cloud AlibabA Feign、Rsocket Gateway等。例如使用Feign进行远程调用时,只需要配置一下Feign客户端指向Nacos的服务列表即可。 5. 实现服务的自动路由:当有新的实例加入或移除时,Nacos 会实时更新,你的服务调用将会自动导向可用的服务实例。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值