【Netty4】
文章平均质量分 81
Netty4
zero__007
这个作者很懒,什么都没留下…
展开
-
ChannelHandler
转载自:http://blog.csdn.net/abc_key/article/details/37928441 Netty提供了一个强大的处理这些事情的功能,允许用户自定义ChannelHandler的实现来处理数据。使得ChannelHandler更强大的是可以连接每个ChannelHandler来实现任务,这有助于代码的整洁和重用。但是处理数据只是ChannelHandle转载 2016-05-02 10:38:21 · 798 阅读 · 0 评论 -
ByteBuf缓冲区
转载自:http://blog.csdn.net/iter_zc/article/details/39478111 Netty的ByteBuf缓冲区实现地比Java本身的ByteBuffer更加灵活,方便。可以参考:http://blog.csdn.net/zero__007/article/details/51326657 为什么要ByteBuf这个组件。主要转载 2017-06-15 18:07:10 · 1960 阅读 · 0 评论 -
PooledByteBuf内存池
转载自:http://blog.csdn.net/youaremoon/article/details/47910971 http://blog.csdn.net/youaremoon/article/details/47984409 http://blog.csdn.net/youaremoon/article/details/4808转载 2017-06-15 18:07:33 · 4477 阅读 · 0 评论 -
LengthFieldBasedFrameDecoder使用示例
转载自:http://blog.csdn.net/z69183787/article/details/52980699 http://blog.163.com/linfenliang@126/blog/static/127857195201210821145721/ LengthFieldBasedFrameDecoder是Netty中一个很重要的转载 2017-06-15 18:33:42 · 2698 阅读 · 1 评论 -
Netty封装的ChannelHandler
转载自:http://www.cnblogs.com/wade-luffy/p/6222960.html ChannelHandler类似于Servlet的Filter过滤器,负责对I/O事件或者I/O操作进行拦截和处理,它可以选择性地拦截和处理自己感兴趣的事件,也可以透传和终止事件的传递。基于ChannelHandler接口,用户可以方便地进行业务逻辑定制,例如打印日志、统一转载 2017-06-15 19:12:37 · 1118 阅读 · 0 评论 -
Netty protobuf的编解码使用
Netty为protobuf提供了两个编码器(ProtobufEncoder,ProtobufVarint32LengthFieldPrepender),两个解码器(ProtobufVarint32FrameDecoder,ProtobufDecoder)。只需要在childHandler()中设置好以上编解码器就可以使用protobuf传输数据。服务器端:.childHandle转载 2017-06-15 19:18:28 · 2849 阅读 · 0 评论 -
ServerBootstrap绑定和连接过程源码分析
转载自:http://blog.csdn.net/iter_zc/article/details/39349177 https://segmentfault.com/a/1190000007283053 https://segmentfault.com/a/1190000007403873 典型的Netty服务器端代码如下,首先需要提供两个EventLoopGroup线程...转载 2018-07-02 22:10:07 · 1165 阅读 · 0 评论 -
ChannelPipeline源码剖析
转载自:https://blog.csdn.net/u010853261/article/details/62218715 http://blog.csdn.net/z69183787/article/details/52623501 在netty中,每个Channel 有且仅有一个ChannelPipeline与之对应,他们的组成关系如下图所示: 每一个Channel都...转载 2018-07-02 23:29:37 · 404 阅读 · 0 评论 -
EventLoop与EventLoopGroup
转载自:https://blog.csdn.net/u010853261/article/details/62043709 https://blog.csdn.net/u010412719/article/details/78107741Reactor线程模型 Reactor线程模型有三种 单线程模型 多线程模型 主从Reactor线程模型 ...转载 2018-07-03 22:18:25 · 3617 阅读 · 0 评论 -
accept、read剖析
转载自:https://blog.csdn.net/u010412719/article/details/78443379 https://blog.csdn.net/u010412719/article/details/78448380 之前分析到了processSelectedKey:private void processSelectedKeys() { if...转载 2018-07-03 23:01:36 · 548 阅读 · 0 评论 -
客户端connect过程分析
转载自:https://blog.csdn.net/pzw_0612/article/details/78068194 BootStrap.connect() 分析:public ChannelFuture connect(String inetHost, int inetPort) { return connect(InetSocketAddress.createUnres...转载 2018-07-03 23:47:40 · 860 阅读 · 0 评论 -
Channel和Unsafe
提起Channel,会想到JDK的NIO类库的重要组成部分:java.nio.SocketChannel和java.nio.ServerSocketChannel,用于非阻塞的I/O操作。 类似于NIO的Channel,Netty提供自己的Channel及其子类实现,用于异步I/O操作和其他相关的操作。 Unsafe是内部接口,聚合在Channel中协助进行网络读写相关的操作,因为...转载 2018-07-07 10:35:55 · 334 阅读 · 0 评论 -
Netty内存池泄漏问题
转载自:https://blog.csdn.net/broadview2006/article/details/84559920 为了提升消息接收和发送性能,Netty针对ByteBuf的申请和释放采用池化技术,通过PooledByteBufAllocator可以创建基于内存池分配的ByteBuf对象,这样就避免了每次消息读写都申请和释放ByteBuf。由于ByteBuf涉及byte[]数组的...转载 2019-01-02 20:48:55 · 2107 阅读 · 0 评论 -
Netty零拷贝
转载自:https://www.cnblogs.com/xys1228/p/6088805.html 所谓的 Zero-copy, 就是在操作数据时, 不需要将数据 buffer 从一个内存区域拷贝到另一个内存区域. 因为少了一次内存的拷贝, 因此 CPU 的效率就得到的提升. 在 OS 层面上的 Zero-copy 通常指避免在 用户态(User-space) 与 内核态(Ker...转载 2019-05-17 22:59:58 · 1305 阅读 · 0 评论 -
Netty百万级推送服务设计要点
转载自:http://blog.csdn.net/kobejayandy/article/details/46318489 作为高性能的NIO框架,利用Netty开发高效的推送服务技术上是可行的,但是由于推送服务自身的复杂性,想要开发出稳定、高性能的推送服务并非易事,需要在设计阶段针对推送服务的特点进行合理设计。1. 最大句柄数修改 百万长连接接入,首先转载 2017-06-14 20:03:50 · 1060 阅读 · 0 评论 -
浅析Netty实现心跳机制与断线重连
转载自:http://blog.csdn.net/z69183787/article/details/52671543 何为心跳:顾名思义, 所谓心跳, 即在 TCP 长连接中, 客户端和服务器之间定期发送的一种特殊的数据包, 通知对方自己还在线, 以确保 TCP 连接的有效性. 为什么需要心跳? 因为网络的不可靠性, 有可能在 TCP转载 2017-06-14 19:45:33 · 1057 阅读 · 0 评论 -
Netty高性能之道
转载自:http://www.infoq.com/cn/articles/netty-high-performance1. 异步非阻塞通信 在IO编程过程中,当需要同时处理多个客户端接入请求时,可以利用多线程或者IO多路复用技术进行处理。IO多路复用技术通过把多个IO的阻塞复用 到同一个select的阻塞上,从而使得系统在单线程的情况下可以同时处理多个客户端请求。与传统的多转载 2016-05-05 21:48:01 · 2261 阅读 · 0 评论 -
Netty心跳和重连
转载自:http://blog.csdn.net/z69183787/article/details/52625095Netty应用心跳和重连的整个过程: 1)客户端连接服务端; 2)在客户端的的ChannelPipeline中加入一个比较特殊的IdleStateHandler,设置一下客户端的写空闲时间,例如5s; 3)当客户端的所有ChannelHa转载 2017-05-23 20:48:34 · 2675 阅读 · 0 评论 -
Netty学习(一)
转载自:http://blog.csdn.net/huaishu/article/details/49953195 http://www.myext.cn/other/a_26003.html http://www.cnblogs.com/luxiaoxun/p/3959450.html1.Netty是什么? Netty 是一个基于 ...转载 2016-02-19 20:26:00 · 485 阅读 · 0 评论 -
Netty核心概念
转载自:http://blog.csdn.net/abc_key/article/details/37672187 一个Netty程序开始于Bootstrap类,Bootstrap类是Netty提供的一个可以通过简单配置来设置或"引导"程序的一个很重要的类。Netty中设计了Handlers来处理特定的"event"和设置Netty中的事件,从而来处理多个协议和数据。事件可以转载 2016-05-02 09:24:54 · 1955 阅读 · 0 评论 -
Bootstrap
转载自:http://blog.csdn.net/abc_key/article/details/38275333 Netty包含了2个不同类型的引导,第一个是使用服务器的ServerBootstrap,用来接受客户端连接以及为已接受的连接创建子通道;第二个是用于客户端的Bootstrap,不接受新的连接,并且是在父通道类完成一些操作。 还有一种情况是处理Datagra转载 2016-05-02 10:08:05 · 1528 阅读 · 0 评论 -
Netty工具类HashedWheelTimer源码走读
HashedWheelTimer主要用来高效处理大量定时任务,且任务对时间精度要求相对不高, 比如链接超时管理等场景, 缺点是, 内存占用相对较高。但是在使用时要注意任务里不要有太耗时的操作, 否则会阻塞Worker线程, 导致tick不准。 源码解读请看下面链接: https://my.oschina.net/haogrgr/blog/489320原创 2017-06-07 20:12:55 · 1877 阅读 · 0 评论 -
Netty User guide
转载自:http://blog.csdn.net/doctor_who2004/article/details/40016103DISCARD服务 DISCARD,是一种丢弃了所有接受到的数据,并不做有任何的响应的协议。以下代码基于netty4.1.11。public class DiscardServerHandler extends ChannelInbound转载 2017-06-07 21:16:19 · 363 阅读 · 0 评论 -
Netty超时控制handler
Netty为超时控制封装了两个类ReadTimeoutHandler和WriteTimeoutHandler,ReadTimeoutHandler,用于控制读取数据的时候的超时,如果在设置时间段内都没有数据读取了,那么就引发超时,然后关闭当前的channel;WriteTimeoutHandler,用于控制数据输出的时候的超时,如果在设置时间段内都没有数据写了,那么就超时。它们都是IdleStat原创 2017-06-07 21:21:05 · 14129 阅读 · 0 评论 -
基于Netty的分布式 RPC 框架
转载自:http://blog.csdn.net/z69183787/article/details/52700274 http://blog.csdn.net/z69183787/article/details/52680941 采用Zookeeper、Netty和spring实现了一个轻量级的分布式RPC框架,这个RPC框架可以算是一个简易版的转载 2017-06-09 18:11:56 · 1227 阅读 · 0 评论 -
Netty Client重连实现
转载自:http://colobu.com/2015/08/14/netty-tcp-client-with-reconnect-handling/当使用Netty实现一个TCP client时,希望当连接断掉的时候Netty能够自动重连。下面来实现这个需求。实现ChannelFutureListener 用来启动时监测是否连接成功,不成功的话重试:public class Client {...转载 2018-04-26 14:45:27 · 5597 阅读 · 1 评论 -
Netty之ByteBuf
在使用NIO时需要使用缓冲区,常用的缓冲区就是JDK NIO类库提供的java.nio.Buffer,而主要使用的是ByteBuffer。但是ByteBuffer也有局限性: 1.ByteBuffer长度固定,一旦分配完成,它的容量就不能动态扩展和收缩,当需要编码的POJO对象大于ByteBuffer的容量时,会发送索引越界异常; 2.ByteBuf...原创 2016-05-05 22:04:34 · 3125 阅读 · 0 评论