Netty -05- Netty介绍

概述

  • Netty 是由 JBOSS 提供的一个 Java 开源框架,现为 Github 上的独立项目

  • Netty 是一个异步的、基于事件驱动的网络应用框架,用以快速开发高性能、高可靠性的网络 IO 程序。

  • Netty 主要针对在 TCP 协议下,面向 Clients 端的高并发应用,或者 Peer-to-Peer 场景下的大量数据持续传输的

    应用。

  • Netty 本质是一个 NIO 框架,适用于服务器通讯相关的多种应用场景

  • 要透彻理解 Netty , 需要先学习 NIO , 这样我们才能阅读 Netty 的源码


原生NIO存在的问题

  • NIO 的类库和 API 繁杂,使用麻烦:需要熟练掌握 Selector、ServerSocketChannel、SocketChannel、ByteBuffer

  • 需要具备其他的额外技能:要熟悉 Java 多线程编程,因为 NIO 编程涉及到 Reactor 模式,你必须对多线程

    和网络编程非常熟悉,才能编写出高质量的 NIO 程序

  • 开发工作量和难度都非常大:例如客户端面临断连重连、网络闪断、半包读写、失败缓存、网络拥塞和异常流

    的处理等等

  • JDK NIO 的 Bug:例如臭名昭著的 Epoll Bug,它会导致 Selector 空轮询,最终导致 CPU 100%。直到 JDK 1.7

    版本该问题仍旧存在,没有被根本解决


优点

Netty 对 JDK 自带的 NIO 的 API 进行了封装,解决了上述问题

  • 设计优雅:适用于各种传输类型的统一 API 阻塞和非阻塞 Socket;基于灵活且可扩展的事件模型,可以清晰

    地分离关注点;高度可定制的线程模型 - 单线程,一个或多个线程池.

  • 使用方便:详细记录的 Javadoc,用户指南和示例;没有其他依赖项,JDK 5(Netty 3.x)或 6(Netty 4.x)就

    足够了

  • 高性能、吞吐量更高:延迟更低;减少资源消耗;最小化不必要的内存复制。

  • 安全:完整的 SSL/TLS 和 StartTLS 支持

  • 社区活跃、不断更新:社区活跃,版本迭代周期短,发现的 Bug 可以被及时修复,同时,更多的新功能会被

    加入


应用场景

互联网行业
  • 互联网行业:在分布式系统中,各个节点之间需要远程服务调用,高性能的 RPC 框架必不可少,Netty 作为

    异步高性能的通信框架,往往作为基础通信组件被这些 RPC 框架使用。

  • 典型的应用有:阿里分布式服务框架 Dubbo 的 RPC 框架使用 Dubbo 协议进行节点间通信,Dubbo 协议默

    认使用 Netty 作为基础通信组件,用于实现各进程节点之间的内部通信


游戏
  • 无论是手游服务端还是大型的网络游戏,Java 语言得到了越来越广泛的应用

  • Netty 作为高性能的基础通信组件,提供了 TCP/UDP 和 HTTP 协议栈,方便定制和开发私有协议栈,账号登

录服务器

  • 地图服务器之间可以方便的通过 Netty 进行高性能的通信

大数据
  • 经典的 Hadoop 的高性能通信和序列化组件 Avro 的 RPC 框架,默认采用 Netty 进行跨界点通信
  • 它的 Netty Service 基于 Netty 框架二次封装实现


下载

 👉 点击官网下载


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值