netty的理解

netty作为nio应用的典范,在很多设计方面都值得我们在程序开发中学习。

1.事件驱动,三种事件的传播机制。一种是在channel上触发,一种是在pipeline上触发,一种是在context上触发。其中前两种触发的事件都会在整个pipeline上进行传播,第三种事件在context后的handler上执行。

2.为了是用户编写handler方便,开发的时候直接继承adapter,将handler感兴趣的进行重写。

3.netty中关于多线程的使用是一个典范,比如锁机制,voli变量和atom变量等。

4.netty支持reactor的单线程模型,多线程模型,以及主从模型,需要进行配置。

netty的理解

时间: 2024-10-12 21:29:33

netty的理解的相关文章

Netty组件理解(转载)

转载的文章,写的非常好. 一.先纵览一下Netty,看看Netty都有哪些组件?   为了更好的理解和进一步深入Netty,我们先总体认识一下Netty用到的组件及它们在整个Netty架构中是怎么协调工作的.Netty应用中必不可少的组件: Bootstrap or ServerBootstrap EventLoop EventLoopGroup ChannelPipeline Channel Future or ChannelFuture ChannelInitializer ChannelH

Netty的几个要点

Netty是一个传输层的框架,主要的功能就是两个:封装了NIO的操作,封装了CodeC接口,从而使得NIO的开发者只需要关注与业务功能本身的ChannelHandler. 不只是Netty,传输层主要解决的问题就是这两个,处理IO,处理CodeC CodeC主要处理的问题就是字节流的分帧(Frame),一般有以下几种 按结束符,比如http 定长 使用消息头消息体的方式,在消息头指定长度,比如TCP, Thrift Netty的前端实现了多线程的Reactor模式,可以指定Accept处理的线程

Netty启动流程剖析

编者注:Netty是Java领域有名的开源网络库,特点是高性能和高扩展性,因此很多流行的框架都是基于它来构建的,比如我们熟知的Dubbo.Rocketmq.Hadoop等,针对高性能RPC,一般都是基于Netty来构建,比如soft-bolt.总之一句话,Java小伙伴们需要且有必要学会使用Netty并理解其实现原理. 关于Netty的入门讲解可参考:Netty 入门,这一篇文章就够了 Netty的启动流程(ServerBootstrap),就是创建NioEventLoopGroup(内部可能包

Netty连接处理那些事

编者注:Netty是Java领域有名的开源网络库,特点是高性能和高扩展性,因此很多流行的框架都是基于它来构建的,比如我们熟知的Dubbo.Rocketmq.Hadoop等,针对高性能RPC,一般都是基于Netty来构建,比如soft-bolt.总之一句话,Java小伙伴们需要且有必要学会使用Netty并理解其实现原理. 关于Netty的入门讲解可参考:Netty 入门,这一篇文章就够了 Netty的连接处理就是IO事件的处理,IO事件包括读事件.ACCEPT事件.写事件和OP_CONNECT事件

我的2015技术学习流水账

我的2015技术学习流水账 2015年马上就要过去了,匆匆忙忙地又是一年.回头总结整理,发现这一年还挺充实的.在正常上班工作之余,学习到了不少新东西,不禁感到很欣慰!一个多月前就开始写,终于赶在2016年来临之前写完了这篇文章-- 关于本文,尽管叫做流水账,但是出于程序员条理性的"强迫症",还是进行系统分类,分类方法参照Thoughtworks技术雷达的Tecniques.Languages & Frameworks.Tools.Platforms,将其中的Tecniques改

Java游戏服务器成长之路——弱联网游戏篇(源码分析)

http://blog.csdn.net/hjcenry/article/details/50530472 前段时间由于公司的一款弱联网游戏急着上线,没能及时分享,现在基本做的差不多,剩下的就是测试阶段了(本来说元旦来分享一下服务器技术的).公司的这款游戏已经上线一年多了,在我来之前一直都是单机版本,由于人民群众的力量太强大,各种内购破解,刷体力,刷金币,刷钻石版本的出现,公司才决定将这款游戏转型为弱联网游戏,压制百分之八十的破解用户(毕竟原则上还是属于单机游戏,不可能做到百分之百的防破解),招

学期末兼19年年终总结

大二下学期即上半年 0.接触到了机器学习算法这一块的东西,但是也知道了自己不适合这些 1.申请了两个小项目,第二个没能上省级,很遗憾 2.自学了安卓,学了一点java后台开发,暑假留校就是在搞这些,感谢,那段时间我过得很充实,很开心 3.过了科一科二 大三上即下半年 0.开学来科三挂,还是因为太紧张 1.感谢陈老师的指导,对项目给出了一些针对性的意见,受益很多,出了第二版,挑战杯院里答辩通过,后面的结果还得等下学期 2.确定好了自己的方向,学了SSM框架,在牛客上认识了很多dalao们,刷了一点

理解netty对protocol buffers的编码解码

一,netty+protocol buffers简要说明 Netty是业界最流行的NIO框架之一优点:1)API使用简单,开发门槛低:2)功能强大,预置了多种编解码功能,支持多种主流协议:3)定制能力强,可以通过ChannelHandler对通信框架进行灵活的扩展:4)性能高,通过与其它业界主流的NIO框架对比,Netty的综合性能最优:5)成熟.稳定,Netty修复了已经发现的所有JDK NIO BUG,业务开发人员不需要再为NIO的BUG而烦恼:6)社区活跃,版本迭代周期短,发现的BUG可以

理解Netty中的零拷贝(Zero-Copy)机制【转】

理解零拷贝 零拷贝是Netty的重要特性之一,而究竟什么是零拷贝呢? WIKI中对其有如下定义: "Zero-copy" describes computer operations in which the CPU does not perform the task of copying data from one memory area to another. 从WIKI的定义中,我们看到"零拷贝"是指计算机操作的过程中,CPU不需要为数据在内存之间的拷贝消耗资源