前言
学习Java总是离不开网络编程的,真是觉得越学习越发现自己很菜,不会的东西还很多,该学习的东西还很多,我的学习就是靠网上各位大佬分享的博客,还有找一些免费视频,当然也会去图书馆借一些书,废话不多说,就歇一歇最近学习的netty框架吧
netty是什么
我所理解的netty,就是一个比较底层的网络编程的框架,它和tomcat的区别是什么呢?就是tomcat是一个已经封装好的容器,你可以直接使用,而netty是可以写出像tomcat这种容器的。而且tomcat支持的网络协议是http,但是使用netty,可以写出支持任何协议的容易。当然,由于我现在只是初雪,所以还没有学的那么深,就只是使用netty实现简单的功能而已。网上很多大神对netty的分析都很深入很到位,优点也说了很多,简单来说,就是使用netty就可以实现性能好,高并发量的功能,他是NIO的封装,总结就是:零拷贝,同意的IO,可拓展的时间模型。其他很多特点可以直接通过官网来了解。下面就是直接上实例了。
netty所需要的环境
这个环境很简单,不需要下载什么插件,只要一个jar包,如果是使用maven工程,可以直接在pom.xml中添加以下jar包:
<dependency>
<groupId>io.netty</groupId>
<artifactId>netty-all</artifactId>
<version>5.0.0.Alpha2</version>
</dependency>
或者去maven仓库下载其他版本的也可以,但是我志气啊用的是4点多版本的,在编码的时候会发现有点错误,所以这里还是使用了5的。
实例
实现聊天室功能需要有服务器端和客户端,先写服务器端。
1.服务器端要创建两个EventLoopGroup监听线程组,一个监听客户请求,一个来处理数据
2.然后要创建一个服务器端ServerBootstrap对象,实现配置信息
3.初始化过程,初始化过程就是绑定线程组,设置NIO的通讯模式,设置缓冲区大小,还有实现处理对象
4.上面说到了处理对象,这时候就要创建一个handler来处理需求了,包括接受数据,发送数据等等
代码如下;
package nettyTest1.nettyTest1;
import java.io.UnsupportedEncodingException;
import io.netty.bootstrap.ServerBootstrap;
import io.netty.channel.ChannelFuture;
import io.netty.channel.ChannelHandler;
import io.netty.channel.ChannelInitializer;
import io.netty.channel.ChannelOption;
import io.netty.channel.EventLoopGroup;
import io.netty.channel.nio.NioEventLoopGroup;
im