JavaGuide面试突击版笔记(四)
作者:互联网
Netty
- Netty 是⼀个 基于 NIO 的 客户端服务器 框架,使⽤它可以快速简单地开发⽹络应⽤程序
NIO是以块的方式处理数据,IO是以最基础的字节流的形式去写入和读出的。所以在效率上的话,NIO效率比IO效率会高出很多
- Netty 应⽤场景
- 作为 RPC 框架的⽹络通信⼯具------在分布式系统中,不同服务节点之间经常需要相互调⽤,这个时候就需要 RPC 框架了
- 实现⼀个⾃⼰的 HTTP 服务器
- 实现⼀个即时通讯系统
- 实现消息推送系统
- Netty 核⼼组件有哪些?分别有什么作⽤
- Channel 接⼝是 Netty 对⽹络操作抽象类,它除了包括基本的 I/O 操作,如bind() 、 connect() 、 read() 、 write()
- EventLoop是 Netty 中最核⼼的概念,负责监听⽹络事件并调⽤事件处理器进⾏相关 I/O 操作的处理
- Channel 为 Netty ⽹络操作 ( 读写等操作 ) 抽象类, EventLoop 负责处理注册到其上的 Channel 处理 I/O 操作,两者配合参与 I/O 操作。
- Bootstrap 和 ServerBootstrap
- Bootstrap 通常使⽤ connet() ⽅法连接到远程的主机和端⼝
- ServerBootstrap 通常使⽤ bind() ⽅法绑定本地的端⼝上,然后等待客户端的连接
- 什么是 TCP 粘包/拆包?有什么解决办法呢
TCP 粘包/拆包 就是你基于 TCP 发送数据的时候,出现了多个字符串“粘”在了⼀起或者 ⼀个字符串被“拆”开的问题
解决办法:
-
使⽤ Netty ⾃带的解码器
-
⾃定义序列化编解码器
- TCP ⻓连接和短连接了解么
TCP 在进⾏读写之前,server 与 client 之间必须提前建⽴⼀个连接。建⽴连接的过程,需要我们常说的三次握⼿,释放/关闭连接的话需要四次挥⼿
短连接说的就是 server 端 与 client 端建⽴连接之后,读写完成之后就关闭掉连接,如果下⼀次再要互相发送消息,就要重新连接
⻓连接说的就是 client 向 server 双⽅建⽴连接之后,即使 client 与 server 完成⼀次读写,它们之间的连接并不会主动关闭,后续的读写操作会继续使⽤这个连接
-
Netty 中⼼跳机制
在 TCP 保持⻓连接的过程中,可能会出现断⽹等⽹络异常出现,异常发⽣的时候, client 与 server 之间如果没有交互的话,它们是⽆法发现对⽅已经掉线的。为了解决这个问题, 我们就需
要引⼊ ⼼跳机制⼼跳机制的⼯作原理是: 在 client 与 server 之间在⼀定时间内没有数据交互时, 客户端或服务器就会发送⼀个特殊的数据包给对⽅, 当接收⽅收到这个数据报⽂后, 也⽴即发送⼀个特殊的数据报⽂, 回应发送⽅, 此即⼀个 PING-PONG 交互
标签:Netty,面试,读写,笔记,server,JavaGuide,client,TCP,连接 来源: https://blog.csdn.net/lijieling123/article/details/115864979