Netty高性能大容量Socket并发(二):Netty简介
来源:互联网 发布:境外网络加速 编辑:程序博客网 时间:2024/06/15 14:36
Netty简介
Netty是由JBOSS提供的一个java开源框架。Netty提供异步的、事件驱动的网络应用程序框架和工具,用以快速开发高性能、高可靠性的网络服务器和客户端程序。和传统BIO不同,NIO是非阻塞的,和传统BIO不同,NIO相当于是线程池方式的BIO,相比BIO一个连接一个线程,NIO能支持更多的连接。BIO适合流量很高的应用,如文件传输,NIO适合流量不高,但是并发很高的应用,如聊天、推送。如果既要高并发,又要高流量的可以选择AIO。
Netty随着最近几年的发展,特别是跟着云计算、大数据的流行,很多开源分布式框架都使用了Netty作为通讯框架,如:Hadoop、Storm、Spark、Facebook、Twitter、阿里巴巴都在使用的Java高性能NIO通信框架,Netty经过多年打磨,其稳定性和性能达到了非常高的程度。
Netty架构
Netty之所以能够提供高并发和高性能的通讯,主要是由以下原因形成的:
- 零拷贝内存池;
- 异步非阻塞通讯模型;
- 高效的Reactor线程模型;
- 无锁化的串行设计;
- 高效的并发编程;
- 高性能的序列化框架;
Netty三个核心组件:Buffer(缓存)、Channel(通道)和ChannelEvent(事件模型)
Netty的缓存分为堆内存(HeapByteBuf)和直接内存(DirectByteBuf)缓冲区。堆内存缓冲区的特点是分配和回收速度快,可以被JVM自动回收,缺点是进行Socket的IO读写,需要额外进行一次内存复制,将堆内存对应的缓冲区复制到内核中,性能会有一定程度的下降;直接内存缓冲区的特点是非堆内存,,它在堆外进行内存分配,相比于堆内存,它的分配和回收速度会慢一些,但是将它写入或者从Socket Channel中读取时,由于少了一次内存复制,速度比堆内存快。
Channel包括但不限于网络的读、写,客户端发起连接,主动关闭连接,链路关闭,获取通信双方的网络地址等,封装了Socket的操作。当有Socket操作发生时,会触发事件响应操作,主要操作包括channelRead、channelReadComplete、exceptionCaught等方法,还包括连接建立和断开等事件。
Netty正是通过Buffer、Channel、ChannelEvent等的封装,实现了高效率,简单易用的Socket并发方案,其编程简单,默认使用的类都具有很好的效率。
2 0
- Netty高性能大容量Socket并发(二):Netty简介
- Netty高性能大容量Socket并发
- Netty高性能大容量Socket并发 二
- Netty高性能大容量Socket并发(一):Netty性能测试
- Netty高性能大容量Socket并发 一
- Netty高性能并发
- DELPHI高性能大容量SOCKET并发(二):IOCP完成端口控件封装
- 高性能大容量SOCKET并发(二):IOCP完成端口控件封装
- 高性能大容量SOCKET并发(二):IOCP完成端口控件封装
- C#高性能大容量SOCKET并发(二):SocketAsyncEventArgs封装
- DELPHI高性能大容量SOCKET并发(八):断点续传
- C#高性能大容量SOCKET并发(九):断点续传
- Netty实现高性能高并发
- DELPHI高性能大容量SOCKET并发(十):IOCP完成端口性能优化
- Netty开发中间件:高并发性能优化
- DELPHI高性能大容量SOCKET并发(一):IOCP完成端口例子介绍
- DELPHI高性能大容量SOCKET并发(三):接收、发送、缓存
- DELPHI高性能大容量SOCKET并发(五):锁和对象分离
- 阿里感悟(十四)-如何带新员工
- oto餐饮app和服务器通信接口和规范定义(三)
- maven spring项目部署问题-source 1.3 中不支持注释 (请使用 -source 5 或更高版本以启用注释)
- 在windows 7搭建xcode开发环境
- open函数中参数选项O_EXCL解析
- Netty高性能大容量Socket并发(二):Netty简介
- NSPredicate 条件查询或过虑
- 按键精灵刷阿里妈妈广告联盟源码 V1.1版
- 杭电1062 Text Reverse
- 我的大学之路---《大学之路》读后感
- iOS QQ第三方登录
- 字体图标
- 客户端和服务端路径问题
- 查找练习 hash——出现过的数字