"[图片] 本文主要是记录在学习 Java - 数据通信 过程中的一些知识点备忘! 一、 RPC:RMI(JDK 自带)、Dubbo、Hessian、Thrift 消息中间件:ActiveMQ、RabbitMQ、RocketMQ、Kafka、Confluo 20181228 1、RPC RPC- 远程过程调用,是一种通过 .."

Java - 数据通信

本贴最后更新于 203 天前,其中的信息可能已经时移世改

    本文主要是记录在学习 Java - 数据通信 过程中的一些知识点备忘!

一、

20181228

1、RPC

RPC- 远程过程调用,是一种通过网络从远程计算机程序上请求服务,而不需要了解底层网络技术的协议。

RPC 协议假定某些传输协议的存在,如 TCP 或 UDP,为通信程序之间携带信息数据,用于开发分布式应用程序。在 OSI 网络通信模型中,RPC 跨越了传输层和应用层。

RPC 采用客户端(服务调用方)/ 服务端(服务提供方)模式,都运行在自己的 JVM 中。客户端只需要引入使用的接口,接口的实现和运行都在服务器端;RPC 主要依赖的技术包括序列号、反序列化和数据传输协议,这是一种定义与实现相分离的设计

RPC 主要指内部服务之间的调用,RESTful 也可以用于内部服务之间的调用但其主要用途还是在于外部系统提供服务

Java 中常见的 RPC 框架有:

如何进行选择?

此外,Google 基于 HTTP2.0 的 gRPC 框架,其序列号协议基于 Protobuf,网络框架使用的是 Netty4,但是其需要生成代码,可扩展性也比较差

1.1、RPC-RMI

1.2、RPC-Dubbo

1.3、RPC-Hessian

1.4、RPC- Thrift

2、消息中间件

消息中间件,也叫做中央消息队列或消息队列(区别于本地消息队列,本地消息队列指的是 JVM 内的队列实现),是一种独立的队列系统;

消息中间件经常用于解决内部服务之间的异步调用问题:请求服务方把请求队列放到队列中即可返回,然后等待服务提供方队列中获取请求进行处理,之后通过回调等机制把结果返回给请求服务方

异步调用仅是消息中间件一个非常常见的应用场景,此外其他的一些常见应用场景有:

常见的消息队列有 ActiveMQ(性能差,不推荐使用)、RabbitMQ、RocketMQ、Kafka、Confluo 等等

2.1、ActiveMQ

2.2、RabbitMQ

2.3、RocketMQ

2.4、Kafka

  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    2214 引用 • 7525 回帖 • 967 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    83 引用 • 294 回帖
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    210 引用 • 1151 回帖 • 413 关注
回帖   
请输入回帖内容...