Java - 数据通信

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

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

一、

  • RPC:RMI(JDK 自带)、Dubbo、Hessian、Thrift
  • 消息中间件:ActiveMQ、RabbitMQ、RocketMQ、Kafka、Confluo

20181228

1、RPC

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

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

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

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

Java 中常见的 RPC 框架有:

  • RMI:JDK 自带的 RPC
  • Dubbo:Alibaba 开源的一个高性能优秀的 RPC 服务框架,使得应用间可通过高性能的 RPC 实现服务的输出和输入功能,可以和 Spring 框架无缝集成
  • Hessian:一个轻量级 RPC 框架,基于 HTTP 协议传输,使用简单的方法提供了 RMI 的功能;相比较于 WebService,Hessian 更简单、快捷;采用二进制序列化,对数据包比较大情况友好
  • Thrift:Facebook 开源的跨语言 RPC 通信框架

如何进行选择?

  • 是否允许代码入侵:即需要依赖相应的代码生成器生成代码,比如 Thrift
  • 是否需要长连接获取高性能:如果对于性能需求较高的话,那么果断可以选择基于 TCP 的 Thrift、Dubbo
  • 是否需要跨域网段、跨越防火墙:这种情况一般选择基于 HTTP 协议的 Hessina 和 Thfrit 的 HTTP Transport

此外,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 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3201 引用 • 8216 回帖
  • 学习

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

    174 引用 • 538 回帖
  • 面试

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

    325 引用 • 1395 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 636 关注
  • OneDrive
    2 引用
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 547 关注
  • 30Seconds

    📙 前端知识精选集,包含 HTML、CSS、JavaScript、React、Node、安全等方面,每天仅需 30 秒。

    • 精选常见面试题,帮助您准备下一次面试
    • 精选常见交互,帮助您拥有简洁酷炫的站点
    • 精选有用的 React 片段,帮助你获取最佳实践
    • 精选常见代码集,帮助您提高打码效率
    • 整理前端界的最新资讯,邀您一同探索新世界
    488 引用 • 384 回帖 • 10 关注
  • sts
    2 引用 • 2 回帖 • 230 关注
  • Maven

    Maven 是基于项目对象模型(POM)、通过一小段描述信息来管理项目的构建、报告和文档的软件项目管理工具。

    188 引用 • 319 回帖 • 251 关注
  • Sphinx

    Sphinx 是一个基于 SQL 的全文检索引擎,可以结合 MySQL、PostgreSQL 做全文搜索,它可以提供比数据库本身更专业的搜索功能,使得应用程序更容易实现专业化的全文检索。

    1 引用 • 223 关注
  • CodeMirror
    2 引用 • 17 回帖 • 162 关注
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 3 关注
  • Anytype
    3 引用 • 31 回帖 • 16 关注
  • Visio
    1 引用 • 2 回帖
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖 • 1 关注
  • 浅吟主题

    Jeffrey Chen 制作的思源笔记主题,项目仓库:https://github.com/TCOTC/Whisper

    1 引用 • 28 回帖 • 1 关注
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 67 回帖 • 451 关注
  • 反馈

    Communication channel for makers and users.

    121 引用 • 907 回帖 • 273 关注
  • 安全

    安全永远都不是一个小问题。

    203 引用 • 818 回帖 • 1 关注
  • BND

    BND(Baidu Netdisk Downloader)是一款图形界面的百度网盘不限速下载器,支持 Windows、Linux 和 Mac,详细介绍请看这里

    107 引用 • 1281 回帖 • 34 关注
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 4 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 812 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 3 关注
  • Hprose

    Hprose 是一款先进的轻量级、跨语言、跨平台、无侵入式、高性能动态远程对象调用引擎库。它不仅简单易用,而且功能强大。你无需专门学习,只需看上几眼,就能用它轻松构建分布式应用系统。

    9 引用 • 17 回帖 • 636 关注
  • Chrome

    Chrome 又称 Google 浏览器,是一个由谷歌公司开发的网页浏览器。该浏览器是基于其他开源软件所编写,包括 WebKit,目标是提升稳定性、速度和安全性,并创造出简单且有效率的使用者界面。

    63 引用 • 289 回帖 • 1 关注
  • Java

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

    3201 引用 • 8216 回帖
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 31 关注
  • 电影

    这是一个不能说的秘密。

    122 引用 • 608 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖