博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
netty编程一:快速入门
阅读量:5286 次
发布时间:2019-06-14

本文共 2621 字,大约阅读时间需要 8 分钟。

服务器端编程

第一步:maven 依赖 netty-all.jar,详情参考文章最后的maven依赖

第二步:创建服务端的NIO线程组EventLoopGroup;

EventLoopGroup bossGroup = new NioEventLoopGroup();EventLoopGroup workerGroup = new NioEventLoopGroup();

第三步:创建并配置服务端启动辅助类ServerBootstrap;

1、创建ServerBootstrap

ServerBootstrap b = new  ServerBootstrap();

2、配置ServerBootstrap实例的线程组(group):绑定线程组

b.group(bossGroup, WorkerGroup);

3、配置ServerBootstrap实例的channel:将创建的channel为NioServerSocketChannel

b.channel(NioServerSocketChannel.class);

4、配置ServerBootstrap实例的option:配置NioServerSocketChannel的tcp参数,eg:将他的backlog设置为1024;

b.option(ChannelOption.SO_BACKLOG, 1024);

5、配置ServerBootstrap实例的childHandler:绑定I/O事件的处理类;eg 半包问题处理,记录日志,数据编码解码,用户自定义的处理等等

// 此处注意:ChildChannelHandler是自定义的,继承了ChannelHandlerAdapter类,netty框架让我们可以集中精力用于实际业务上的数据处理,此处的内容后续文章在做重点分析b.childHandler(new ChildChannelHandler());

6、配置ServerBootstrap实例的绑定并监听port与等待链路的关闭:绑定port,并调用同步阻塞方法sync来等待绑定操作完成,完成后会返回channelFuture实例(异步操作的通知回调)

// 绑定端口,同步等待绑定成功ChannelFuture  f = b.bind(8888).sync();// 阻塞等待服务端监听端口关闭,目的:等待服务端链路关闭后main函数才退出f.channel().closeFuture().sync();

7、注意:退出时,记得释放线程池资源

try{    // 服务器启动辅助类的创建与配置内容    // ...  }finally{    // 优雅退出,通过调用线程组的shutdownGracefully方法释放相关资源    bossGroup.shutdownGracefully();      workerGroup.shutdownGracefully();  }

 

客户端编程

第一步:maven 依赖 netty-all.jar

第二步:创建客户端的NIO线程组EventLoopGroup;

EventLoopGroup group = new NioEventLoopGroup();

第三步:创建并配置客户端启动辅助类Bootstrap;

1、创建Bootstrap

Bootstrap b = new  Bootstrap();

2、配置Bootstrap实例的线程组(group):绑定线程组

b.group(group);

3、配置Bootstrap实例的channel:将创建的channel为NioSocketChannel

b.channel(NioSocketChannel.class);

4、配置Bootstrap实例的option:配置NioSocketChannel的tcp参数,eg:将他的nodelay设置为true;

b.option(ChannelOption.TCP_NODELAY, true);

5、配置Bootstrap实例的handler:绑定I/O事件的处理类;eg 半包问题处理,记录日志,数据编码解码,用户自定义的处理等等

// 此处注意:TimeClientHandler是自定义的,继承了ChannelHandlerAdapter类,netty框架让我们可以集中精力用于实际业务上的数据处理,此处的内容后续文章在做重点分析b.handler(new ChannelInitializer
(){ @Override public void initChannel(SocketChannel ch) throws Exception{ ch.pipeline().addLast(new TimeClientHandler()) }});

6、配置Bootstrap实例的绑定并监听port与等待链路的关闭:绑定port,并调用同步阻塞方法sync来等待绑定操作完成,完成后会返回channelFuture实例(异步操作的通知回调)

// 绑定服务器的IP和端口,同步等待连接指定服务器成功ChannelFuture  f = b.connect(127.0.0.1,8888).sync();// 阻塞等待服务端监听端口关闭,目的:等待服务端链路关闭后main函数才退出f.channel().closeFuture().sync();

7、注意:退出时,记得释放线程池资源

try{    // 服务器启动辅助类的创建与配置内容    // ...  }finally{    // 优雅退出,通过调用线程组的shutdownGracefully方法释放相关资源    group.shutdownGracefully();  }

 

关于netty的maven依赖

io.netty
netty-all
4.1.33.Final

 

转载于:https://www.cnblogs.com/outpointexception/p/10428985.html

你可能感兴趣的文章
[洛谷P1738]洛谷的文件夹
查看>>
ubuntu server设置时区和更新时间
查看>>
【京东咚咚架构演进】-- 好文收藏
查看>>
【HTML】网页中如何让DIV在网页滚动到特定位置时出现
查看>>
文件序列化
查看>>
jQuery之end()和pushStack()
查看>>
Bootstrap--响应式导航条布局
查看>>
Learning Python 009 dict(字典)和 set
查看>>
JavaScript中随着鼠标拖拽而移动的块
查看>>
HDU 1021 一道水题
查看>>
The operation couldn’t be completed. (LaunchServicesError error 0.)
查看>>
php每天一题:strlen()与mb_strlen()的作用分别是什么
查看>>
工作中收集JSCRIPT代码之(下拉框篇)
查看>>
《转载》POI导出excel日期格式
查看>>
code异常处理
查看>>
git - 搭建最简单的git server
查看>>
会话控制
查看>>
推荐一款UI设计软件Balsamiq Mockups
查看>>
Linux crontab 命令格式与详细例子
查看>>
百度地图Api进阶教程-地图鼠标左右键操作实例和鼠标样式6.html
查看>>