栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Netty | 第2章 Netty 简介《Netty In Action》

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Netty | 第2章 Netty 简介《Netty In Action》

第2章 Netty 简介
  • 前言
  • 1. Netty 简介
  • 2. Netty 的核心组件
    • 2.1 Channel
    • 2.2 回调
    • 2.3 Future
    • 2.4 事件和 ChannelHandler
    • 2.5 Netty 的设计
  • 最后


前言

参考资料:

  • 《Netty In Action》;

本系列为 Netty 学习笔记,本篇介绍总结Netty 简介。主要参考书籍《Netty In Action》的第一章,对 Netty 做大概介绍;


1. Netty 简介
  • Netty 是一个异步的、基于事件驱动的网络应用框架;

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

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

  • Netty 的特性总结:

    分类Netty 的特性
    设计统一的 API,支持多种传输种类,阻塞和非阻塞的;无连接数据报套接字支持;链接逻辑组件支持复用
    易于使用JDK 1.8+ 的依赖;文档资料多
    性能比 Java 核心 API 更高的吞吐量以及更低的延迟
    健壮性在慢速、快速或超载的连接下正常运行;
    安全性完整的 SSL/TLS 以及 StartTLS 支持
    社区驱动发布快速且频繁
  • 异步和可伸缩性间的关系:

    • 异步允许我们以任意顺序响应在任意时间点产生的事件;
    • 可伸缩性要求我们在需要处理的工作不断增长时,处理它的能力也要扩大;
    • 非阻塞网络调用允许我们不必等待一个操作的完成;
    • 完全异步 IO 在完成时,会直接或在稍后某个时间点通知用户;
    • 选择器使得我们能够通过较少的线程便可监视许多连接上的事件;

2. Netty 的核心组件 2.1 Channel
  • Channel 是 Java NIO 的一个基本构造;
  • 它代表一个到实体的开放连接;
  • Channel 可以是传入(入站)或传出(出站)数据的载体;它可以被打开或关闭,连接或断开连接;
2.2 回调
  • 回调指:一个指向已经被提供给另外一个方法的方法的引用;
  • Netty 在内部使用回调处理事件:当一个回调被触发时,相关事件可以被一个 interface-ChannelHandler 是实现处理;
2.3 Future
  • Future 提供另一种在操作完成时通知应用程序的方法;
  • Netty 提供自己的实现——ChannelFuture,用于在执行异步操作时使用;
  • 监听器的回调方法 operationComplete(),将会在对应的操作完成是被调用;
  • 每个 Netty 的出站 IO 操作都会返回一个 ChannelFuture;
2.4 事件和 ChannelHandler
  • Netty 使用不同的事件来通知我们状态的改变或操作的状态。这使得我们能够基于发生的事件来触发适当的动作;
  • 由入站数据或相关状态更改而触发的事件包括:
    • 连接已被激活或者连接失败;
    • 数据读取;
    • 用户事件;
    • 错误事件;
  • 出站事件是在未来会触发的某个动作的结果,这些动作有:
    • 打开或关闭到远程节点的连接;
    • 将数据写到或冲刷到套接字;

2.5 Netty 的设计
  • Netty 的异步编程模型建立在 Future 和回调之上,而将事件派发到 ChannelHandler 的方法发生在更深的层次上;
  • 拦截操作以及高速地转换入站数据和出站数据,都只需要提供回调或者利用操作所返回的 Future;
  • Netty 通过触发事件将 Selector 从应用程序中抽象出来,消除了原有将需要手动编写的派发代码;
  • 在内部,Netty 会为每个 Channel 分配一个 EventLoop,用以处理所有事件;
  • EventLoop 本身是一个线程驱动,其处理了一个 Channel 的所有 IO 事件,并且在该 EventLoop 的整个生命周期内不会改变;


最后
新人制作,如有错误,欢迎指出,感激不尽!
欢迎关注公众号,会分享一些更日常的东西!
如需转载,请标注出处!
另外,下边有个程序员学习求职分享交流群
是我跟科锐国际的 HR 合作的
里面会分享发布一些求职就业相关的东西
也可以来交流学习技术,欢迎扫码进群
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/643078.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号