RPC学习笔记一

什么是RPC

RPC(Remote Procedure Call,远程过程调用)是一种用于实现分布式系统中不同计算机或进程之间进行通信和调用的技术和模式。

在传统的过程调用中,当一个程序需要调用另一个程序的函数或方法时,通常是在同一台计算机上进行。而在分布式系统中,不同的计算机或进程可能分布在不同的物理位置上,RPC提供了一种透明的机制,使得在远程计算机上调用函数或方法就像在本地调用一样简单。

RPC的基本原理 是,客户端程序发起一个函数调用请求,然后通过网络将请求发送到远程的服务端程序。服务端接收到请求后,执行相应的函数或方法,并将结果返回给客户端。这个过程对于客户端来说是透明的,就好像调用本地函数一样,无需关心底层的网络通信细节。

RPC过程

client 调用远程方法-> request序列化 -> 协议编码 -> 网络传输-> 服务端 -> 反序列化request ->

调用本地方法得到response -> 序列化 ->编码->......


Dubbo(现称 Apache Dubbo)是一个开源的高性能跨语言RPC框架,由阿里巴巴开发并于2011年开源。它旨在简化分布式系统的开发,提供高性能和可扩展性,并支持多种编程语言。

以下是 Dubbo 的一些主要特性:

  • 高性能:Dubbo 在设计上注重性能,并采用了多种优化策略,如基于 Netty 的 NIO 异步通信、高效的序列化机制和请求响应模式等,以提供低延迟和高吞吐量的 RPC 调用。

  • 服务治理:Dubbo 提供了丰富的服务治理功能,包括服务注册与发现、负载均衡、容错机制、路由策略、动态配置等。这些功能使得开发者能够更好地管理和控制分布式系统中的服务。

  • 跨语言支持:Dubbo 支持多种编程语言,包括 Java、Python、Node.js 等,在不同语言之间提供了无缝的集成和调用。

  • 高度可扩展:Dubbo 提供了可扩展的体系架构,允许开发者通过扩展点机制来自定义和扩展各种功能,以满足特定的业务需求。

  • 配置中心:Dubbo 提供了配置中心,可以集中管理和配置分布式系统中的服务配置,支持实时推送和动态更新配置。

  • 监控和管理:Dubbo 提供了丰富的监控和管理工具,包括服务调用监控、性能指标统计、服务治理控制台等,帮助开发者实时监控和管理分布式系统。


Lombok是一个流行的Java库,旨在通过提供注解来自动生成代码,从而减少Java应用程序中的样板代码。

以下是Lombok的一些主要功能:

  • 自动生成Getter和Setter:使用@Getter和@Setter注解,Lombok可以自动为类的字段生成对应的Getter和Setter方法。

  • 自动生成构造函数:使用@NoArgsConstructor、@AllArgsConstructor和@RequiredArgsConstructor等注解,Lombok可以根据字段自动生成无参构造函数、全参构造函数和指定字段的构造函数。

  • 自动生成toString方法:使用@ToString注解,Lombok可以自动生成类的toString方法,包括类的所有字段。

  • 自动生成Equals和HashCode方法:使用@EqualsAndHashCode注解,Lombok可以自动生成类的equals和hashCode方法,根据指定的字段进行比较。

  • 自动生成日志记录:使用@Slf4j或其他相关日志注解,Lombok可以自动生成日志记录器(Logger)。

  • 自动化异常抛出:使用@SneakyThrows注解,Lombok可以自动为方法抛出异常。

  • 链式调用:使用@Builder注解,Lombok可以自动生成构建器模式的代码,实现链式调用。

相关推荐
2301_8029399025 分钟前
从零开始学习Redis(五):多级缓存
redis·学习·缓存
Chunyyyen1 小时前
【第二十周】自然语言处理的学习笔记05
笔记·学习·自然语言处理
笨鸟笃行1 小时前
百日挑战——单词篇(第十一天)
学习
yong15858553433 小时前
1. Linux C++ muduo 库学习——库的编译安装
linux·c++·学习
952363 小时前
数据结构-顺序表
java·数据结构·学习
码界奇点3 小时前
Java Web学习 第1篇前端基石HTML 入门与核心概念解析
java·前端·学习·xhtml
星辰大海14124 小时前
摄影入门学习笔记
笔记·数码相机·学习
沐矢羽4 小时前
upload文件上传漏洞浅析
学习·web安全·网络安全·文件上传·top10
朝新_4 小时前
【SpringBoot】配置文件
java·spring boot·笔记·后端·spring·javaee
shenghaide_jiahu5 小时前
数学分析简明教程——2.3 (未完)
学习