netty启动流程
本文通过对netty服务端、客户端的启动流程分析, 让大家对netty是如何启动运行的。
废话不多说,上源码!!!
建议读者学习netty下的jar类型为 netty-example,里面有很多example可以供我们参考学习,本系列文章netty的版本为4.1.25.Final,5.X版本有重大bug官方已抛弃
<dependency>
<groupId>io.netty</groupId>
<artifactId>netty-example</artifactId>
<version>4.1.25.Final</version>
</dependency>
打开如图所示的jar位置,即可看到echo下的案例,echoserver和echoclient对应服务端启动器和客户端启动器,可直接运行
我们先来看服务端的启动流程
EventLoopGroup bossGroup = new NioEventLoopGroup(1); //用来处理accpet事件,并指定EventLoop数量为一个
EventLoopGroup workerGroup = new NioEventLoopGroup(); //用来处理后续的io事件,这里没有指定EventLoop数量 默认为CPU核心数*2
try {
ServerBootstrap b = new ServerBootstrap(); //创建一个服务端netty启动器,用来帮助服务端启动
b.group(bossGroup, workerGroup) //把刚才创建的eventloopGroup添加进去
.channel(NioServerSocketChannel.class) //服务端对应的channel类型,这里是用来创建连接时候用的
.option(ChannelOption.SO_BACKLOG, 100) //设置bossgroup得到的最大连接数
.handler(new LoggingHandler(LogLevel.INFO)) //给NioServerScoketChannel设置的处理器 该handler看名字就知道是用来打印流程日志
//上面都是设置bossgroup产生连接使用的 只对NioServerScoketChannel有效
//产生连接后会相应生成NioSocketChannel用来会后续客户端io事件的处理
.childHandler(new ChannelInitializer<SocketChannel>() { //该handler在NioSocketChannel创建的时候使用,ChannelInitializer用来帮助channel的创建
@Override
public void initChannel(SocketChannel ch) throws Exception {
ChannelPipeline p = ch.pipeline();
p.addLast(new EchoServerHandler()); //这里才是像channel添加handler
}
});
// 绑定端口并同步阻塞
ChannelFuture f = b.bind(PORT).sync();
// 监听NioServerScoketChannel的关闭事件,同步阻塞
f.channel().closeFuture().sync();
} finally {
// 结束后优雅的关闭
bossGroup.shutdownGracefully();
workerGroup.shutdownGracefully();
}
跟我们之前所述一样,服务端这边有两个EventLoopGroup,分别是bossGroup和workGroup,bossGroup仅用来处理客户端连接,完成连接后会创建一个socketchannel交给workGroup中其中一个EventLoop,后续的io操作都在这个EventLoop完成
我们再来看客户端启动流程
EventLoopGroup group = new NioEventLoopGroup(); //客户端只有一个EventLoopGroup 因为客户端连接、读写事件都是由一个channel完成
try {
Bootstrap b = new Bootstrap(); //客户端启动器
b.group(group)
.channel(NioSocketChannel.class) //指定客户端channel类型 后续创建时通过反射来实例化
.option(ChannelOption.TCP_NODELAY, true) //设置NioSocketChannel类型为tcp无延迟
.handler(new ChannelInitializer<SocketChannel>() { //帮助NioSocketChannel创建的handler
@Override
public void initChannel(SocketChannel ch) throws Exception {
ChannelPipeline p = ch.pipeline();
p.addLast(new EchoClientHandler()); //添加NioSocketChannel的handler
}
}); // 连接服务端,同步阻塞
ChannelFuture f = b.connect(HOST, PORT).sync(); // 等待客户关闭信号,同步阻塞
f.channel().closeFuture().sync();
} finally {
// 结束后记得关闭
group.shutdownGracefully();
}
客户端启动流程和服务端大致类似,差别在于服务端有一个专门处理accpet事件的NioServerScoketChannel,跟jdk中Nio一样
我们对netty服务端和客户端启动流程简单进行的阐述,先让大家有个基本印象
netty启动流程的更多相关文章
- Netty源码分析第1章(Netty启动流程)---->第3节: 服务端channel初始化
Netty源码分析第一章:Netty启动流程 第三节:服务端channel初始化 回顾上一小节的initAndRegister()方法: final ChannelFuture initAndRe ...
- Netty源码分析第1章(Netty启动流程)---->第4节: 注册多路复用
Netty源码分析第一章:Netty启动流程 第四节:注册多路复用 回顾下以上的小节, 我们知道了channel的的创建和初始化过程, 那么channel是如何注册到selector中的呢?我们继 ...
- Netty启动流程剖析
编者注:Netty是Java领域有名的开源网络库,特点是高性能和高扩展性,因此很多流行的框架都是基于它来构建的,比如我们熟知的Dubbo.Rocketmq.Hadoop等,针对高性能RPC,一般都是基 ...
- Netty源码分析第1章(Netty启动流程)---->第1节: 服务端初始化
Netty源码分析第一章: Server启动流程 概述: 本章主要讲解server启动的关键步骤, 读者只需要了解server启动的大概逻辑, 知道关键的步骤在哪个类执行即可, 并不需要了解每一步的 ...
- Netty源码分析第1章(Netty启动流程)---->第2节: NioServerSocketChannel的创建
Netty源码分析第一章: Server启动流程 第二节:NioServerSocketChannel的创建 我们如果熟悉Nio, 则对channel的概念则不会陌生, channel在相当于一个通 ...
- Netty源码分析第1章(Netty启动流程)---->第5节: 绑定端口
Netty源码分析第一章:Netty启动步骤 第五节:绑定端口 上一小节我们学习了channel注册在selector的步骤, 仅仅做了注册但并没有监听事件, 事件是如何监听的呢? 我们继续跟第一小节 ...
- netty服务端客户端启动流程分析
服务端启动流程 我们回顾前面讲解的netty启动流程,服务端这边有两个EventLoopGroup,一个专门用来处理连接,一个用来处理后续的io事件 服务端启动还是跟nio一样,绑定端口进行监听,我们 ...
- Netty 拆包粘包和服务启动流程分析
Netty 拆包粘包和服务启动流程分析 通过本章学习,笔者希望你能掌握EventLoopGroup的工作流程,ServerBootstrap的启动流程,ChannelPipeline是如何操作管理Ch ...
- 【转】Netty 拆包粘包和服务启动流程分析
原文:https://www.cnblogs.com/itdragon/archive/2018/01/29/8365694.html Netty 拆包粘包和服务启动流程分析 通过本章学习,笔者希望你 ...
随机推荐
- espcms代码审计(二次urldecode注入分析)
这里提到的漏洞是二次urldecode注入 这里用到的还是espcms,不过版本应该跟之前的有所不同,在网上找到的espcms源代码都是已经修补了这个漏洞的,我们对比分析吧 先放上漏洞位置代码,也就是 ...
- LeetCode初级算法之数组:350 两个数组的交集 II
两个数组的交集 II 题目地址:https://leetcode-cn.com/problems/intersection-of-two-arrays-ii/ 给定两个数组,编写一个函数来计算它们的交 ...
- js中单引号和双引号区别
总结: 1.无论单引号还是双引号都是成双成对出现的,否则报错!浏览器在读到第一个双引号开始,第二个双引号结束,同样浏览器读取单引号也是第一个开始,第二个单引号结束,在使用的时候必须遵循规则那就是一对双 ...
- 题解 CF504E 【Misha and LCP on Tree】
PullShit 倍增和树剖的差距!!! 一个 TLE, 一个 luogu 最优解第三!!! 放个对比图(上面倍增,下面轻重链剖分): 不过这是两只 log 非正解... Solution \(LCP ...
- CSP-S2020复赛游记
[本文经过删改] 前一个月 没做什么 NOIP 的题,感觉这些题对我这个做黄题封顶的人不是很友好. 前一天 考了场模拟赛,全场最低分 89,感觉信心满满. 退役那天 到了 XJ,发现没人可以面基,想着 ...
- 八、git学习之——忽略特殊文件、配置别名、搭建git服务器
原文来自 一.忽略特殊文件 有些时候,你必须把某些文件放到Git工作目录中,但又不能提交它们,比如保存了数据库密码的配置文件啦,等等,每次git status都会显示Untracked files . ...
- Big Sur 11.0.1 让2K屏幕开启Hidpi
首先来个成果图: 一.复制显示器配置文件 终端输入命令:cd /System/Library/Displays/Contents/Resources/Overrides 接着输入:open . 打开D ...
- 程序员必读的 99 本书籍 & 资源
作为程序员,始终要保持学习,一直带着纸质书还是很不便的,因此电子书对于我们还是挺需要的.为了方便广大的小伙伴也能方便找到对应的电子书,我花费洪荒之力从各个搜索网站收集了几百本常用的电子书,找到了,我要 ...
- 确定Linux系统位数
1:getconf LONG_BIT 2:uname -a 3:uname -r 4:cat /proc/version
- 爬取并分析一下B站的最热视频排行榜,看看大家都喜欢看什么视频
前言 现在大家的生活中,已经越来越离不开B站了,2020年的第一季度,B站月活跃用户达到了1.72亿,日活跃用户也已经突破了5000万个用户.源源不断的流量让B站的up主们也是粉丝数目不断暴涨,百万粉 ...