JavaGuide面试突击版笔记(四)

Netty

  • Netty 是⼀个 基于 NIO 客户端服务器 框架,使⽤它可以快速简单地开发⽹络应⽤程序

NIO是以块的方式处理数据,IO是以最基础的字节流的形式去写入和读出的。所以在效率上的话,NIO效率比IO效率会高出很多

  • Netty 应⽤场景
  1. 作为 RPC 框架的⽹络通信⼯具------在分布式系统中,不同服务节点之间经常需要相互调⽤,这个时候就需要 RPC 框架了
  2. 实现⼀个⾃⼰的 HTTP 服务器
  3. 实现⼀个即时通讯系统
  4. 实现消息推送系统
  • Netty 核⼼组件有哪些?分别有什么作⽤
  1. Channel 接⼝是 Netty 对⽹络操作抽象类,它除了包括基本的 I/O 操作,如bind() connect() read() write()
  2. EventLoop Netty 中最核⼼的概念,负责监听⽹络事件并调⽤事件处理器进⾏相关 I/O 操作的处理
  3. Channel Netty ⽹络操作 ( 读写等操作 ) 抽象类, EventLoop 负责处理注册到其上的 Channel 处理 I/O 操作,两者配合参与 I/O 操作。
 
  • Bootstrap ServerBootstrap 
  1. Bootstrap 通常使⽤ connet() ⽅法连接到远程的主机和端⼝
  2. ServerBootstrap 通常使⽤ bind() ⽅法绑定本地的端⼝上,然后等待客户端的连接
  •  
  • 什么是 TCP 粘包/拆包?有什么解决办法呢

TCP 粘包/拆包 就是你基于 TCP 发送数据的时候,出现了多个字符串在了⼀起或者 ⼀个字符串被“开的问题

解决办法:

  1. 使⽤ Netty ⾃带的解码器

  2. ​​​⾃定义序列化编解码器

  • TCP ⻓连接和短连接了解么

​​​​​​​​TCP 在进⾏读写之前,server client 之间必须提前建⽴⼀个连接。建⽴连接的过程,需要我们常说的三次握⼿,释放/关闭连接的话需要四次挥⼿

 

短连接说的就是 server 端 与 client 端建⽴连接之后,读写完成之后就关闭掉连接,如果下⼀次再要互相发送消息,就要重新连接

⻓连接说的就是 client server 双⽅建⽴连接之后,即使 client server 完成⼀次读写,它们之间的连接并不会主动关闭,后续的读写操作会继续使⽤这个连接

  • Netty 中⼼跳机制

​​​​​​​在 TCP 保持⻓连接的过程中,可能会出现断⽹等⽹络异常出现,异常发⽣的时候, client 与 server 之间如果没有交互的话,它们是⽆法发现对⽅已经掉线的。为了解决这个问题, 我们就需

要引⼊ ⼼跳机制
 

⼼跳机制的⼯作原理是: client server 之间在⼀定时间内没有数据交互时, 客户端或服务器就会发送⼀个特殊的数据包给对⽅, 当接收⽅收到这个数据报⽂后, 也⽴即发送⼀个特殊的数据报⽂, 回应发送⽅, 此即⼀个 PING-PONG 交互

 

 


 

2020/5月/15好上传最新 JavaGuide 目前已经 70k+ Star ,目前已经是所有 Java 类别项目中 Star 数量第二的开源项目了。Star虽然很多,但是价值远远比不上 Dubbo 这些开源项目,希望以后可以多出现一些这样的国产开源项目。国产开源项目!加油!奥利给! 随着越来越多的人参与完善这个项目,这个专注 “Java知识总结+面试指南 ” 项目的知识体系和内容的不断完善。JavaGuide 目前包括下面这两部分内容: Java 核心知识总结; 面试方向:面试题、面试经验、备战面试系列文章以及面试真实体验系列文章 内容的庞大让JavaGuide 显的有一点臃肿。所以,我决定将专门为 Java 面试所写的文章以及来自读者投稿的文章整理成 《JavaGuide面试突击》 系列,同时也为了更加方便大家阅读查阅。起这个名字也犹豫了很久,大家如果有更好的名字的话也可以向我建议。暂时的定位是将其作为 PDF 电子书,并不会像 JavaGuide 提供在线阅读本。我之前也免费分享过PDF 本的《Java面试突击》,期间一共更新了 3 个本,但是由于后面难以同步和订正所以就没有再更新。《JavaGuide面试突击》 pdf 由于我工作流程的转变可以有效避免这个问题。 另外,这段时间,向我提这个建议的读者也不是一个两个,我自己当然也有这个感觉。只是自己一直没有抽出时间去做罢了!毕竟这算是一个比较耗费时间的工程。加油!奥利给! 这件事情具体耗费时间的地方是内容的排优化(为了方便导出PDF生成目录),导出 PDF 我是通过 Typora 来做的。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值