1.Netty介绍及NIO三大组件

  1. Netty网络编程
  2. Netty的底层是NIO(非阻塞IO),常用的多线程和线程池使用的是阻塞IO,其效率并不高。
  3. 支持高并发,性能好
  4. 高性能的服务端程序、客户端程序

NIO三大组件

一、Channel

读写数据的双向传输通道

常见的传输通道

  • FIleChannel 文件传输通道
  • DatagramChannel UDP数据传输通道
  • SocketChannel TCP数据传输通道,专用于服务器、客户端
  • ServerSocketChannel TCP数据传输通道,专用于服务器

二、Buffer

内存缓冲区,用来暂存从channel中读取的数据,也可以将channel中的数据写入Buffer。

常用的Buffer

ByteBuffer,以字节的形式,抽象类:

  • MappedByteBuffer
  • DirectByteBuffer
  • HeapByteBuffer

三、Selector

  • Selector配合一个线程来管理多个Channel;
  • 获得这些Channel上发生的事件 (可连接,可读,可写);
  • Channel工作在非阻塞模式下,不会让线程吊死在一个Channel上;
  • 适合连接数多,但流量低的场景
相关推荐
iwS2o90XT3 分钟前
Java多线程编程:Thread与Runnable的并发控制
java·开发语言·python
wangchunting12 分钟前
spring-boot-starter-validation字段数据校验
java
阿Y加油吧13 分钟前
堆 / 优先队列专题二刷笔记:前 K 个高频元素 & 数据流的中位数
java·笔记·算法
凯尔萨厮16 分钟前
创建Springboot空项目
java·spring boot
深邃-37 分钟前
【Web安全】-Kali,Linux配置(2):Java环境配置,Python环境配置,Conda使用,PIP配置使用,SSH远程登录
java·linux·python·安全·web安全·网络安全·php
jjjava2.038 分钟前
Java多线程编程:从入门到实战
java·开发语言
Seven9739 分钟前
Tomcat 线程池的设计与实现:StandardThreadExecutor
java
爱笑的Sunday39 分钟前
Linux Java前后端项目 企业级0-1完整部署手册
java·linux·运维·服务器
xyx-3v40 分钟前
FreeRTOS队列通信
java·服务器·网络