文档章节

netty4.0 研究 ing ... ...

石头哥哥
 石头哥哥
发布于 2013/03/11 14:03
字数 421
阅读 2438
收藏 2

之前做过一个基于netty3.X版本的server,性能测试很不错,现在netty4.0已经出beta2版本beta3的快照也出来了,相信不久就会发布,先尝鲜,总结了一些东西:


#The shutdown process of a typical network application is composed of the following three steps:
#
#Close all server sockets if there are any,
#
#Close all non-server sockets (i.e. client sockets and accepted sockets) if there are any, and
#
#Release all resources used by ServerBootstrap or Bootstrap.


action:
#2. How do I incorporate my blocking application code with the non-blocking NioEventLoopGroup?
#
#NioEventLoopGroup contains n Threads that handle the IO of all the registered Channels.
#
#If your applicaiton's handler blocks such as (reading from a database) or is CPU intensive, the worker thread pool maybe exhausted and performance will degrade.
#
#We recommend that you implement your blocking application code in another thread pool. You can do this by adding your handler with an extra EventExecutor to the ChannelPipeline.
#
#  1 public static void main(String[] args) throws Exception {
#  2         final EventExecutor executor = new DefaultEventExecutor(8);
#
#  4         ServerBootstrap bootstrap = new ServerBootstrap();
#            bootstrap.group(new NioEventLoopGroup(), new NioEventLoopGroup());
#  6         bootstrap.childHandler(new ChannelInitializer<Channel>() {
#                @Override
#  8             public void initChannel(Channel channel) {
#                    ChannelPipeline pipeline = channel.pipeline();
# 10                 pipeline.addLast("decoder", new HttpRequestDecoder());
#                    pipeline.addLast("aggregator", new HttpChunkAggregator(65536));
# 12                 pipeline.addLast("encoder", new HttpResponseEncoder());
#                    pipeline.addLast("chunkedWriter", new ChunkedWriteHandler());
# 14
#                    // MyHandler contains code that blocks so add it with the
# 16                 // EventExecutor to the pipeline.
#                    pipeline.addLast(executor, "handler", new MyHandler());
# 18             }
#            });
# 20         ...
#
# 22         sb.bind(socketAddress);
#
# 24         // Other code
#
# 26     }
#
# 28
#        public class MyHandler extends SimpleChannelUpstreamHandler {
# 30         // Your blocking application code
#    }





netty4变化较大,不管是线程池管理还是buffer,新添加了AIO,但是建议还是用nio(个人观点),但是根据开发者帮助文档,基本上也可以快速实现一个稳定高效的服务端(TCP/IP)socket长连接。

有关netty4.0 持续关注中... ...  有时间的话 将会很快写一个基于netty4.0的server。

http://netty.io/4.0/guide/#faq.3,在上面可以找到很多资料,并且快速上手,如果你对netty3足够熟悉的话。

http://netty.io/4.0/xref/(source)

© 著作权归作者所有

共有 人打赏支持
石头哥哥
粉丝 303
博文 203
码字总数 120417
作品 2
渝中
程序员
私信 提问
C# 自定义FileUpload控件

摘要:ASP.NET自带的FileUpload控件会随着浏览器的不同,显示的样式也会发生改变,很不美观,为了提高用户体验度,所以我们会去自定义FileUpload控件 实现思路:用两个Button和TextBox控件来...

annehan
2016/05/27
0
0
不联网、不插U盘,黑客用声音直接整垮你的硬盘

2008年,一位叫 Brendan Gregg 的网红工程师,在油管上发布了一个很“鬼畜”的视频↓↓↓ 视频一开始,他在一个非常嘈杂的数据中心里告诉大家,他正在使用一款软件监测硬盘的 IOPS (Input/Ou...

郭佳
2018/06/06
0
0
解析土豆视频下载地址以及硕鼠网原理

在讨论区看了这个问题,对这个问题蛮感兴趣的然后就研究了下。尝试了下土豆。 下面是步骤哈 1. 用ie打开www.tudou.com/programs/view/YDnzTq8gI/一个视频链接。 2.然后打开浏览器缓存文件 然...

小囧
2012/10/12
0
2
[python爬虫] 招聘信息定时系统 (一).BeautifulSoup爬取信息并存储MySQL

这系列文章主要讲述,如何通过Python爬取招聘信息,且爬取的日期为当前天的,同时将爬取的内容保存到数据库中,然后制作定时系统每天执行爬取,最后是Python调用相关库发送短信到手机。 最近...

Eastmount
2017/04/22
0
0
【简书交友】既见君子,云胡不喜

突然想到的很喜欢的一句“既见君子,云胡不喜”作题目,虽然放在这里有点不妥,但也懒得改了,毕竟我就是一个很懒惰的猪猪女孩呢。 突然发现像我这种身高只有 160,体重却在100斤的小个子中的...

一喵喵喵一
2018/03/24
0
0

没有更多内容

加载失败,请刷新页面

加载更多

利用神器BTrace 追踪线上 Spring Boot应用运行时信息

概述 生产环境中的服务可能会出现各种问题,但总不能让服务下线来专门排查错误,这时候最好有一些手段来获取程序运行时信息,比如 接口方法参数/返回值、外部调用情况 以及 函数执行时间等信...

CodeSheep
55分钟前
4
0
OSChina 周四乱弹 —— 我想过年请假提前回家两天

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @clouddyy :#每日一歌# 分享王力宏的单曲《爱错》 《爱错》- 王力宏 手机党少年们想听歌,请使劲儿戳(这里) @Caremorele :这几天起床有点...

小小编辑
今天
169
7
Cookie 显示用户上次访问的时间

import javax.servlet.ServletException;import javax.servlet.annotation.WebServlet;import javax.servlet.http.Cookie;import javax.servlet.http.HttpServlet;import javax.serv......

gwl_
今天
1
0
网络编程

第14天 网络编程 今日内容介绍  网络通信协议  UDP通信  TCP通信 今日学习目标  能够辨别UDP和TCP协议特点  能够说出UDP协议下两个常用类名称  能够说出TCP协议下两个常用类名称...

stars永恒
今天
3
0
二进制相关

二进制 众所周知计算机使用的是二进制,数字的二进制是如何表示的呢? 实际就是逢二进一。比如 2 用二进制就是 10。那么根据此可以推算出 5的二进制等于 10*10+1 即为 101。 在计算机中,负数以...

NotFound403
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部