Netty是什么?
本质:JBoss做的一个Jar包
目的:快速开发高性能、高可靠性的网络服务器和客户端程序
优点:提供异步的、事件驱动的网络应用程序框架和工具
通俗的说:一个好使的处理Socket的东东
如果没有Netty?
远古:java.net + java.io
近代:java.nio
其他:Mina,Grizzly
为什么不是Mina?
1、都是Trustin Lee的作品,Netty更晚;
3、Netty的文档更清晰,很多Mina的特性在Netty里都有;
4、Netty更新周期更短,新版本的发布比较快;
Netty的特性
设计
统一的API,适用于不同的协议(阻塞和非阻塞)
基于灵活、可扩展的事件驱动模型
高度可定制的线程模型
可靠的无连接数据Socket支持(UDP)
性能
更好的吞吐量,低延迟
更省资源
尽量减少不必要的内存拷贝
安全
完整的SSL/TLS和STARTTLS的支持
能在Applet与Android的限制环境运行良好
健壮性
不再因过快、过慢或超负载连接导致OutOfMemoryError
不再有在高速网络环境下NIO读写频率不一致的问题
易用
完善的JavaDoc,用户指南和样例
简洁简单
仅信赖于JDK1.5
- /**
- * Netty 服务端代码
- *
- * @author lihzh
- * @alia OneCoder
- * @blog http://www.coderli.com
- */
- public class HelloServer {
- public static void main(String args[]) {
- // Server服务启动器
- ServerBootstrap bootstrap = new ServerBootstrap(
- new NioServerSocketChannelFactory(
- Executors.newCachedThreadPool(),
- Executors.newCachedThreadPool()));
- // 设置一个处理客户端消息和各种消息事件的类(Handler)
- bootstrap
- .setPipelineFactory(new ChannelPipelineFactory() {
- @Override
- public ChannelPipeline getPipeline()
- throws Exception {
- return Channels
- .pipeline(new HelloServerHandler());
- }
- });
- // 开放8000端口供客户端访问。
- bootstrap.bind(new InetSocketAddress(8000));
- }
- private static class HelloServerHandler extends
- SimpleChannelHandler {
- /**
- * 当有客户端绑定到服务端的时候触发,打印"Hello world, I'm server."
- *
- * @alia OneCoder
- * @author lihzh
- */
- @Override
- public void channelConnected(
- ChannelHandlerContext ctx,
- ChannelStateEvent e) {
- System.out.println("Hello world, I'm server.");
- }
- }
- }
- /**
- * Netty 客户端代码
- *
- * @author lihzh
- * @alia OneCoder
- * @blog http://www.coderli.com
- */
- public class HelloClient {
- public static void main(String args[]) {
- // Client服务启动器
- ClientBootstrap bootstrap = new ClientBootstrap(
- new NioClientSocketChannelFactory(
- Executors.newCachedThreadPool(),
- Executors.newCachedThreadPool()));
- // 设置一个处理服务端消息和各种消息事件的类(Handler)
- bootstrap.setPipelineFactory(new ChannelPipelineFactory() {
- @Override
- public ChannelPipeline getPipeline() throws Exception {
- return Channels.pipeline(new HelloClientHandler());
- }
- });
- // 连接到本地的8000端口的服务端
- bootstrap.connect(new InetSocketAddress(
- "127.0.0.1", 8000));
- }
- private static class HelloClientHandler extends SimpleChannelHandler {
- /**
- * 当绑定到服务端的时候触发,打印"Hello world, I'm client."
- *
- * @alia OneCoder
- * @author lihzh
- */
- @Override
- public void channelConnected(ChannelHandlerContext ctx,
- ChannelStateEvent e) {
- System.out.println("Hello world, I'm client.");
- }
- }
- }
优秀的设计----事件驱动
优秀的设计----线程模型