`
秋天的童话穷
  • 浏览: 79324 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Netty框架之异步事件驱动模型

    博客分类:
  • Java
阅读更多

Netty使用了异步的事件驱动模型,来触发网络I/O的各种操作,其在socket层上面封装一层异步事件驱动模型,使得业务代码不需要关心网络底层,就可以编写异步的无网络I/O阻塞的代码。

 

Netty的异步事件驱动模型主要涉及到下面几个核心的概念:

  •   Channel:表示一个与socket关联的通道
  •  ChannelPipeline: 管道,一个Channel拥有一个ChannelPipeline,ChannelPipeline维护着一个处理链(严格的说是两 个:upstream、downstream),处理链是由很多处理句柄ChannelHandler所构成,每个ChannelHandler处理完以 后会传递给链中的下一个处理句柄继续处理。
  •   ChannelHandler:处理句柄,用户可以定义自己的处理句柄来处理每个请求,或发出请求前进行预处理,典型的有编码/解码器:decoder、encoder。
  •  ChannelEvent:事件,是整个模型的处理对象,当产生或触发(fire)一个事件时,该事件会沿着ChannelPipeline处理链依次被处理。
  •  ChannelFuture: 异步结果,这个是异步事件处理的关键,当一个事件被处理时,可以直接以ChannelFuture的形式直接返回,不用在当前操作中被阻塞。可以通过 ChannelFuture得到最终的执行结果,具体的做法是在ChannelFuture添加监听器listener,当操作最终被执行完 后,listener会被触发,我们可以在listener的回调函数中预定义我们的业务代码。
  • 模型的结构图如下:
  • ChannelPipeline实际上维持了两个处理链:upstream、downstream。 Upstream一般处理来自Channel的读事件,而downstream一般处理向Channel的写事件。需要注意的是,这两个处理链是相互独立 的,在upstream链中传递到最后一个ChannelHandler处理后,不会再传递到downstream链中继续处理。

           在downstream链的末端会有个ChannelSink处理,用户可以自定义这个ChannelSink的实现,系统也有个默认的实现,当downstream链中最后一个ChannelHandler处理完后会被传递给这个ChannelSink进行最后的处理。

  • 引用:http://blog.chinaunix.net/uid-25885064-id-3425708.html
  • 大小: 51.5 KB
分享到:
评论

相关推荐

    Android基于Netty框架实现通信

    Netty是一个高性能、异步事件驱动的网络应用程序框架,适用于多种协议的服务器和客户端应用。本篇文章将详细探讨如何在Android环境中利用Netty来构建通信系统。 首先,我们需要理解Android环境对Netty的特殊性。...

    事件驱动模型

    事件驱动模型是一种软件设计模式,它基于异步通信和消息传递的概念来构建应用程序。在这种模型中,系统的行为是由发生的事件来触发的,而不是由预先设定的顺序执行的指令。事件可以是用户操作、硬件状态改变、定时器...

    netty框架 jar包

    Netty的事件驱动模型基于“事件循环”(Event Loop)和“管道”(Channel Pipeline)的概念。事件循环是Netty中的核心组件,负责处理I/O事件,并将这些事件分发到对应的处理器。管道则是一系列处理器的链,每个...

    netty,netty项目-一个事件驱动的异步网络应用框架.zip

    Netty的核心设计理念是事件驱动和异步非阻塞I/O模型,这种模式在处理高并发连接时能展现出卓越的性能。 Netty的异步特性源于其对Java NIO(非阻塞I/O)的深度利用。传统的阻塞I/O在等待数据读取或写入时会占用线程...

    netty框架图及netty面试知识点解析

    Netty框架是一个高性能、异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。它是Java领域中的热门选择,尤其在处理高并发、低延迟的网络应用时,如分布式系统、游戏服务器、RPC服务等...

    通信框架Netty技术分享.pptx

    Netty框架技术分享 ...Netty框架是一个强大且灵活的网络应用程序框架,具有异步、事件驱动、 高性能、高可靠等特性。它可以快速开发高性能、高可靠的网络服务器和客户端程序,且具有广泛的应用前景。

    java Netty 框架例子源码.rar

    Java Netty 是一个高性能、异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。Netty 提供了一组高度抽象的API,使得开发者可以更专注于业务逻辑,而无需深入理解底层网络通信的复杂性...

    基于Netty框架的RPC服务.zip

    Netty是一个高性能、异步事件驱动的网络应用框架,适用于快速开发可维护的高性能协议服务器和客户端。本项目利用Netty的强大功能,实现了RPC服务的客户端和服务端,支持服务的注册、发现和远程调用。 项目的主要...

    Netty 框架学习 —— 第一个 Netty 应用(csdn)————程序.pdf

    Netty是一个高性能、异步事件驱动的网络应用程序框架,广泛应用于Java领域的服务器开发。 1. Echo服务器的实现: Echo服务器的核心在于`ChannelHandler`的实现。在Netty中,`ChannelHandler`接口用于处理网络事件...

    netty高性能异步I/O服务器/客户端开源开发工具

    Netty的核心是基于NIO(非阻塞I/O)和EventLoop事件驱动模型,这使得它能够在单线程或多线程环境下高效地处理大量并发连接。 1. **异步I/O**:Netty采用非阻塞I/O模型,允许在等待I/O操作完成时执行其他任务,从而...

    Java-NIO-Netty框架学习

    1. **异步事件驱动**:Netty采用事件驱动模型,通过事件循环(EventLoop)和事件处理器(ChannelHandler)处理I/O事件,使得在高并发场景下性能卓越。 2. **零拷贝**:Netty支持零拷贝技术,减少了内存到内存的数据...

    Netty进阶之路-跟着案例学Netty

    《Netty进阶之路-跟着案例学Netty》是由知名技术专家李林峰撰写的一本专为Java开发者深入理解Netty框架而准备的书籍。这本书旨在通过实例教学,帮助读者全面掌握Netty的核心特性和实战技巧,提升网络编程的能力。 ...

    SSM+Netty框架搭建

    4. **Netty**:是一个高性能、异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端。Netty的非阻塞I/O模型使得它在高并发场景下表现优秀。 要实现SSM+Netty的整合,首先需要配置Spring...

    Netty实战 电子版.pdf_java_netty_服务器_

    1. **异步模型**:Netty基于Java NIO(非阻塞I/O)构建,采用异步事件驱动模式,提高了并发处理能力。在高并发场景下,这种模型比传统的同步I/O模型具有更高的性能和更低的延迟。 2. **Channel与Pipeline**:Netty...

    基于Netty框架的Android内网推送demo

    4. **多线程与异步处理**:Netty采用非阻塞I/O,需要理解异步事件驱动模型和线程池的工作原理。 5. **数据传输格式**:可能涉及到JSON、protobuf等数据序列化协议,用于客户端和服务端之间的数据交换。 6. **...

    Java_Netty项目是一个事件驱动的异步网络应用框架.zip

    这个项目基于事件驱动和非阻塞I/O模型,能够优化系统资源的使用,提高系统的并发处理能力。Netty的核心设计理念是简化网络通信的复杂性,提供了一套高度可定制、易于使用的API,使得开发者可以快速地构建出可靠、...

    Java Netty 分布式开发 框架

    Netty是一个高性能、异步事件驱动的网络应用程序框架,用于快速开发可维护的高性能协议服务器和客户端,是基于Java NIO的异步非阻塞的网络编程框架。Netty在内部实现了自己的线程模型,支持多种协议,包括UDP、TCP、...

    Netty核心精讲之Reactor线程模型源码分析.mp4

    Netty是一款高性能、异步事件驱动的网络应用框架,它为Java开发人员提供了构建服务器和客户端的高效工具。在深入探讨Netty的Reactor线程模型源码之前,我们需要先理解Reactor模式的基本概念。 Reactor模式是一种...

Global site tag (gtag.js) - Google Analytics