Netty 介绍和应用场景(一)

1.为什么选择Netty

上一篇文章我们已经了解了Socket通信(IO/NIO/AIO)编程,对于通信模型已经有了一个基本的认识。,果想把这些真正的用于实际工作中,那么还需要不断的完善、扩展和优化。比如经典的TCP读包写包问题,或者是数据接收的大小,实际的通信处理与应答的处理逻辑等等一些细节问题需要认真的去思考,而这些都需要大量的时间和经历,以及丰富的经验。所以想学好Socket通信不是件容易事,那么接下来就来学习一下新的技术Netty,为什么会选择Netty?因为它简单!使用Netty不必编写复杂的逻辑代码去实现通信,再也不需要去考虑性能问题,不需要考虑编码问题,半包读写等问题。强大的Netty已经帮我们实现好了,我们只需要使用即可。

Netty是最流行的NIO框架,它的健壮性、功能、性能、可定制性和可扩展性在同类框架都是首屈一指的。它已经得到成百上千的商业/商用项目验证,如Hadoop的RPC框架Avro、RocketMQ以及主流的分布式通信框架Dubbox等等。

2.Netty简介

Netty是基于Java NIO client-server的网络应用框架,使用Netty可以快速开发网络应用,例如服务器和客户端协议。Netty提供了一种新的方式来开发网络应用程序,这种新的方式使它很容易使用和具有很强的扩展性。Netty的内部实现是很复杂的,但是Netty提供了简单易用的API从网络处理代码中解耦业务逻辑。Netty是完全基于NIO实现的,所以整个Netty都是异步的。

网络应用程序通常需要有较高的可扩展性,无论是Netty还是其他的基于Java Nio的框架,都会提供可扩展性的解决方案。Netty中一个关键组成部分是它的异步特性,本片文章将讨论同步(阻塞)和异步(非阻塞)的IO来说明为什么使用异步代码解决扩展性问题以及如何使用异步。
总结:

1) Netty 是由 JBOSS 提供的一个 Java 开源框架, 现为 Github 上的独立项目。
2) Netty 是一个异步的、 基于事件驱动的网络应用框架, 用以快速开发高性能、 高可靠性的网络 IO 程序。
3) Netty 主要针对在 TCP 协议下, 面向 Clients 端的高并发应用, 或者 Peer-to-Peer 场景下的大量数据持续传输的
应用。
4) Netty 本质是一个 NIO 框架, 适用于服务器通讯相关的多种应用场景。

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

3 Netty 的应用场景
3.1互联网行业
1) 互联网行业: 在分布式系统中, 各个节点之间需要远程服务调用, 高性能的 RPC 框架必不可少, Netty 作为
异步高性能的通信框架, 往往作为基础通信组件被这些 RPC 框架使用。
2) 典型的应用有: 阿里分布式服务框架 Dubbo RPC 框架使用 Dubbo 协议进行节点间通信, Dubbo 协议默
认使用 Netty 作为基础通信组件, 用于实现各进程节点之间的内部通信
3.2游戏行业
1) 无论是手游服务端还是大型的网络游戏, Java 语言得到了越来越广泛的应用
2) Netty 作为高性能的基础通信组件, 提供了 TCP/UDP HTTP 协议栈, 方便定制和开发私有协议栈, 账号登
录服务器
3) 地图服务器之间可以方便的通过 Netty 进行高性能的通信

扫描二维码关注公众号,回复: 8071599 查看本文章

 

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

 3.4其它开源项目使用到 Netty
网址: https://netty.io/wiki/related-projects.html

 学习资料

猜你喜欢

转载自www.cnblogs.com/dalianpai/p/11983801.html
今日推荐