笔者的男装网店:http://shop101289731.taobao.com .冬装,在寒冷的冬季温暖你.新品上市,环境选购 =================================不华丽的分割线=============================== 因为公司使用的是Netty框架.所以也就去学习了一下.貌似Netty虽然是一个蛮不错的开源框架.但是国内的文档貌似都不是很多.绝大部分都是3.x版本的资料.二最新的版本是4.0.11final(我目前使用的版本) Netty 官…
Netty学习——Netty和Protobuf的整合(二) 这程序是有瑕疵的,解码器那里不通用,耦合性太强,有两个很明显的问题,但是要怎么解决呢?如:再加一个内部类型 Person2,之前的代码就不能用了. 问题1:客户端和服务器端 分别 这里解码器都不能写死吧 问题2:客户端和服务器端Handler里面的泛型,也都不能写死吧 Stack Overflow , 善用搜索引擎解决此问题 在Stack Overflow上面搜的结果https://stackoverflow.com/questions…
Netty学习——Netty和Protobuf的整合 Protobuf作为序列化的工具,将序列化后的数据,通过Netty来进行在网络上的传输 1.将proto文件里的java包的位置修改一下,然后再执行一下protoc 异常捕获:启动服务器端正常,在启动客户端的时候,发送消息,报错 警告: An exceptionCaught() event was fired, and it reached at the tail of the pipeline. It usually means the l…
io.netty.buffer.AbstractByteBuf#calculateNewCapacity  申请内存空间 private int calculateNewCapacity(int minNewCapacity) { final int maxCapacity = this.maxCapacity; // 1m = 1024kb = 1024*1024b final int threshold = 1048576 * 4; // 4 MiB page if (minNewCapac…
一.客户端开发时序图 图片来源:Netty权威指南(第2版) 二.Netty客户端开发步骤 使用Netty进行客户端开发主要有以下几个步骤: 1.用户线程创建Bootstrap Bootstrap b = new Bootstrap(); Bootstrap是Socket客户端创建工具类,通过API设置创建客户端相关的参数,异步发起客户端连接. 2.创建处理客户端连接.IO读写的Reactor线程组NioEventLoopGroup EventLoopGroup group = new NioE…
在Netty学习笔记(一) 实现DISCARD服务中,我们使用Netty和Python实现了简单的丢弃DISCARD服务,这篇,我们使用Netty实现服务端和客户端交互的需求. 前置工作 开发环境 JDK8 Netty版本:5.0.0.Alpha2 集成环境:IDEA 构建工具:Gradle 依赖 compile group: 'io.netty', name: 'netty-all', version: '5.0.0.Alpha2' compile group: 'org.projectlom…
前言 本文主要从 select 和 epoll 系统调用入手,来打开 Netty 的大门,从认识 Netty 的基础原理 —— I/O 多路复用模型开始.   Netty 的通信原理 Netty 底层的通信机制是基于I/O多路复用模型构建的,简单一句话概括就是多路网络连接可以复用一个I/O线程,在 Java 层面也就是封装了其 NIO API,但是 JDK 底层基于 Linux 的 epoll 机制实现(其实是三个函数).注意在老旧的 Linux 上,可能还是 select,没考证过,但是时下主…
序 之前开过品味性能系列.Mysql学习系列,颇为曲高和寡.都是讲理论,很少有手把手深入浅出的文章.不过确实我就这脾气,文雅点的说法叫做"伪雅",下里巴人叫做"装逼". 学习资料 本篇文章,打算总结下学习过程,分析学习要点. 关于netty的资料颇多,学习起来未免杂乱.对于初学者麻烦点在于难以找到重点,再此则推荐一个学习路线. Netty 实战(精髓) Netty权威指南 通信理论学习,akka bio nio aio(可以绕过) 第一步 上手练习 Telnet示例…
最近在学习netty,看的是<netty权威指南 第2版>. 然后看的同时也把书上面的代码一行行敲下来做练习,不过到第三章就出问题了. 按照书上讲的,sever/client端都需要继承ChannelHandlerAdapter这个类,然后重写channelActive().channelRead()等几个方法. 然后就是进行到这里,我以外的发现ChannelHandlerAdapter里面其实并没有那几个要被重写的方法,因此就算把程序运行起来也会发现程序没反应. 然后如果我把ChannelH…
在前几节我们学习过处理粘包和拆包的问题,用到了Netty提供的几个解码器对不同情况的问题进行处理.功能很是强大.我们有没有去想这么强大的功能是如何实现的呢?背后又用到了什么技术?这一节我们就来处理这个问题.了解一下编码解码到底是如何处理的. 通常说的编码(Encoder)也就是发生在发送消息的时候需要将消息编译成字节对象,在Netty中即编译成ByteBuf对象.在java中我们将这种编译称之为序列化(Serializable),即将对象序列化为字节数组,然后用于传输或是持久化啊之类的.那么自然…