作者:小哇说互联
来源:www.toutiao.com/i6745361206137061895/

1)dubbo 支持哪些通信协议?

2)支持哪些序列化协议?

3)说一下 Hessian 的数据结构?

4)PB 知道吗?

5)为什么 PB 的效率是最高的?

面试官心理分析

上一个问题,说说 dubbo 的基本工作原理,那是你必须知道的,至少要知道 dubbo 分成哪些层,然后平时怎么发起 rpc 请求的,注册、发现、调用,这些是基本的。

接着就可以针对底层进行深入的问问了,比如第一步就可以先问问序列化协议这块,就是平时 RPC 的时候怎么走的?

面试题剖析

序列化,就是把数据结构或者是一些对象,转换为二进制串的过程,而反序列化是将在序列化过程中所生成的二进制串转换成数据结构或者对象的过程

Dubbo 支持不同的通信协议

1、dubbo 协议

默认就是走 dubbo 协议,单一长连接,进行的是 NIO 异步通信,基于 hessian 作为序列化协议。使用的场景是:传输数据量小(每次请求在 100kb 以内),但是并发量很高。

为了要支持高并发场景,一般是服务提供者就几台机器,但是服务消费者有上百台,可能每天调用量达到上亿次!此时用长连接是最合适的,就是跟每个服务消费者维持一个长连接就可以,可能总共就 100 个连接。然后后面直接基于长连接 NIO 异步通信,可以支撑高并发请求。

长连接,通俗点说,就是建立连接过后可以持续发送请求,无须再建立连接。

2、rmi 协议

走 Java 二进制序列化,多个短连接,适合消费者和提供者数量差不多的情况,适用于文件的传输,一般较少用。

3、hessian 协议

走 hessian 序列化协议,多个短连接,适用于提供者数量比消费者数量还多的情况,适用于文件的传输,一般较少用。

4、http 协议

走 json 序列化。

5、webservice

走 SOAP 文本

Dubbo 支持的序列化协议?

dubbo 支持 hession、Java 二进制序列化、json、SOAP 文本序列化多种序列化协议。但是 hessian 是其默认的序列化协议。

说一下 Hessian 的数据结构?

Hessian 的对象序列化机制有 8 种原始类型:

  • 原始二进制数据

  • boolean

  • 64-bit date(64 位毫秒值的日期)

  • 64-bit double

  • 32-bit int

  • 64-bit long

  • null

  • UTF-8 编码的 string

另外还包括 3 种递归类型:

  • list for lists and arrays

  • map for maps and dictionaries

  • object for objects

还有一种特殊的类型:

  • ref:用来表示对共享对象的引用。

为什么 PB 的效率是最高的?

可能有一些同学比较习惯于 JSON or XML 数据存储格式,对于 Protocol Buffer 还比较陌生。

Protocol Buffer 其实是 Google 出品的一种轻量并且高效的结构化数据存储格式,性能比 JSON、XML 要高很多。

其实 PB 之所以性能如此好,主要得益于两个:

第一,它使用 proto 编译器,自动进行序列化和反序列化,速度非常快,应该比 XML 和 JSON 快上了 20~100 倍;

第二,它的数据压缩效果好,就是说它序列化后的数据量体积小。因为体积小,传输起来带宽和速度上会有优化。

Dubbo 序列化协议 5 连问,这谁接得住啊?相关推荐

  1. Dubbo 序列化协议 5 连问,你接得住不?

    1)dubbo 支持哪些通信协议? 2)支持哪些序列化协议? 3)说一下 Hessian 的数据结构? 4)PB 知道吗? 5)为什么 PB 的效率是最高的? 面试官心理分析 上一个问题,说说 dub ...

  2. Dubbo 支持哪些序列化协议? Hessian 的数据结构?什么是PB ?为什么 PB 的效率是最高的?

    面试题 dubbo 支持哪些通信协议?支持哪些序列化协议?说一下 Hessian 的数据结构?PB 知道吗?为什么 PB 的效率是最高的? 面试官心理分析 上一个问题,说说 dubbo 的基本工作原理 ...

  3. JAVA RPC(二)序列化协议杂谈

    序列化和反序列化作为Java里一个较为基础的知识点,大家心里也有那么几句要说的,但我相信很多小伙伴掌握的也就是那么几句而已,如果再深究问一下Java如何实现序列化和反序列化的,就可能不知所措了!遥记当 ...

  4. 招银网络二面:什么是序列化?常见的序列化协议有哪些?

    今天分享一道读者面试招银网络科技遇到的面试真题. 下面是正文. 序列化和反序列化相关概念 什么是序列化?什么是反序列化? 如果我们需要持久化 Java 对象比如将 Java 对象保存在文件中,或者在网 ...

  5. 架构师之路 — 分布式系统 — Protocol Buffers 序列化协议

    目录 文章目录 目录 Protocol Buffers 序列化协议 定义数据结构 序列化传输 Protocol Buffers 序列化协议 Protocol Buffers 是一种高性能的.语言无关的 ...

  6. 【全栈接口测试进阶系列教程】精通api接口测试,接口分类,接口架构,http,webservice,dubbo接口协议,接口流程,接口工具,cookie,session,token接口鉴权原理以及实战

    目录 一,[什么是接口测试?为什么要作接口测试] 1.接口的作用 2.为什么要做接口测试 3.接口都有哪些类型? 二,[接口测试的分类] 接口的分类: http和webservice接口区别: 三,[ ...

  7. 微服务架构-高性能Netty服务器-064:Netty实战与反序列化与序列化协议

    064:Netty实战与反序列化与序列化协议 1 回顾上节课TCP协议粘包拆分解决方案 2 Java序列化与反序列化的概念 3 Java实现对象持久化操作 4 构建String类型客户与服务器端通讯 ...

  8. 一文彻底理解Redis序列化协议,你也可以编写Redis客户端

    前提 最近学习Netty的时候想做一个基于Redis服务协议的编码解码模块,过程中顺便阅读了Redis服务序列化协议RESP,结合自己的理解对文档进行了翻译并且简单实现了RESP基于Java语言的解析 ...

  9. Thrift源码解析(二)序列化协议

    概述 对于一个RPC框架,定义好网络数据的序列化协议是最基本的工作,thrift的序列化协议主要包含如下几种: TBinaryProtocol TCompactProtocol TJSONProtoc ...

最新文章

  1. C++ .h(头文件) 与 .cpp(源文件) 的使用
  2. Promise 化回调式函数
  3. Spring Boot-@Value获取值和@ConfigurationProperties获取值的比较
  4. [Java基础]权限修饰符
  5. Exynos4412 中断处理流程详解
  6. SAP中Search help的使用
  7. java 正则判断二进制_用正则表达式判断一个二进制数是否能被3整除
  8. WIN10 VMWARE 虚拟机安装WIN10 64系统
  9. Android Gradle配置构建
  10. 尚硅谷大数据Flink从入门到实战(2020最新版)
  11. saas和pass的区别
  12. 互联网下载.deb安装包
  13. 发布个小软件给大伙玩玩
  14. Linux基础命令:awk
  15. VS2015 保护视力 背景色设置
  16. 神武临时服回服务器在那个位置,2021年6月25日游戏更新公告
  17. Python tkinter改变光标样式
  18. https之证书验证
  19. js-变量、数据类型、数据类型转换
  20. 西门子1200PLC和Modbus485从站设备通讯

热门文章

  1. 代码之谜(一)- 有限与无限
  2. nodejs 日志规范
  3. Vue+axios配置踩坑记录
  4. 006-spring-data-elasticsearch 3.0.0.0使用【四】-spring-data之Elasticsearch Repositories
  5. 朝夕科技网络版GIS地图解决方案
  6. 【翻译】Apache Hbase新特性--MOB支持(一)
  7. JAVA数据库连接的另一种实现及简单的数据插入及显示
  8. Android应用权限管理总结
  9. myeclipse使用太卡问题
  10. SharePoint PowerShell命令系列 (9) New-SPWeb