本文通过对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启动流程的更多相关文章

  1. Netty源码分析第1章(Netty启动流程)---->第3节: 服务端channel初始化

    Netty源码分析第一章:Netty启动流程   第三节:服务端channel初始化 回顾上一小节的initAndRegister()方法: final ChannelFuture initAndRe ...

  2. Netty源码分析第1章(Netty启动流程)---->第4节: 注册多路复用

    Netty源码分析第一章:Netty启动流程   第四节:注册多路复用 回顾下以上的小节, 我们知道了channel的的创建和初始化过程, 那么channel是如何注册到selector中的呢?我们继 ...

  3. Netty启动流程剖析

    编者注:Netty是Java领域有名的开源网络库,特点是高性能和高扩展性,因此很多流行的框架都是基于它来构建的,比如我们熟知的Dubbo.Rocketmq.Hadoop等,针对高性能RPC,一般都是基 ...

  4. Netty源码分析第1章(Netty启动流程)---->第1节: 服务端初始化

    Netty源码分析第一章:  Server启动流程 概述: 本章主要讲解server启动的关键步骤, 读者只需要了解server启动的大概逻辑, 知道关键的步骤在哪个类执行即可, 并不需要了解每一步的 ...

  5. Netty源码分析第1章(Netty启动流程)---->第2节: NioServerSocketChannel的创建

    Netty源码分析第一章:  Server启动流程 第二节:NioServerSocketChannel的创建 我们如果熟悉Nio, 则对channel的概念则不会陌生, channel在相当于一个通 ...

  6. Netty源码分析第1章(Netty启动流程)---->第5节: 绑定端口

    Netty源码分析第一章:Netty启动步骤 第五节:绑定端口 上一小节我们学习了channel注册在selector的步骤, 仅仅做了注册但并没有监听事件, 事件是如何监听的呢? 我们继续跟第一小节 ...

  7. netty服务端客户端启动流程分析

    服务端启动流程 我们回顾前面讲解的netty启动流程,服务端这边有两个EventLoopGroup,一个专门用来处理连接,一个用来处理后续的io事件 服务端启动还是跟nio一样,绑定端口进行监听,我们 ...

  8. Netty 拆包粘包和服务启动流程分析

    Netty 拆包粘包和服务启动流程分析 通过本章学习,笔者希望你能掌握EventLoopGroup的工作流程,ServerBootstrap的启动流程,ChannelPipeline是如何操作管理Ch ...

  9. 【转】Netty 拆包粘包和服务启动流程分析

    原文:https://www.cnblogs.com/itdragon/archive/2018/01/29/8365694.html Netty 拆包粘包和服务启动流程分析 通过本章学习,笔者希望你 ...

随机推荐

  1. filebeat输出结果到elasticsearch的多个索引

    基本环境: filebeat版本:6.5.4 (Linux,x86-64) elasticsearch版本:6.54   (一)需求说明 在一台服务器上有多个日志需要使用filebeat日志收集到el ...

  2. UOJ80 二分图最大权匹配

    草,学了一下午假板子,sb博客害人 题目大意: 一个教室有\(n\)个男生和\(m\)个女生,某些男女之间愿意早恋(雾),其早恋好感度为\(w_i\),问怎样让男女配对使得班里好感度之和最大 \(n\ ...

  3. P4085 [USACO17DEC]Haybale Feast

    我又开始水了,感觉又是一道虚假的蓝题 题意 非常好理解,自己看吧 题解 可以比较轻易的发现,如果对于一段满足和大于等于 \(m\) 的区间和其满足和大于等于 \(m\) 的子区间来说,选择子区间肯定是 ...

  4. 题解-Quantifier Question

    Quantifier Question 有长度为 \(n\) 的序列 \(x\{n\}\),有 \(m\) 个条件 \((j_i,k_i)\).有 \(n\) 个待定的条件符 \(Q_i\in\{\f ...

  5. DjangoRestFramework使用

    目录: 1.1 DjangoRestFramework基本使用 1.2 drf认证&权限 模块 1.3 djangorestframework 序列化 1.4 djangorestframew ...

  6. sql server如何把退款总金额拆分到尽量少的多个订单中

    一.问题 原来有三个充值订单,现在要退款450元,如何分配才能让本次退款涉及的充值订单数量最少?具体数据参考下图: 二.解决方案 Step 1:对可退金额进行降序排列,以便优先使用可退金额比较大的订单 ...

  7. 精尽Spring MVC源码分析 - 文章导读

    该系列文档是本人在学习 Spring MVC 的源码过程中总结下来的,可能对读者不太友好,请结合我的源码注释 Spring MVC 源码分析 GitHub 地址 进行阅读 Spring 版本:5.2. ...

  8. I/O-外部设备

    目录 输入设备 输出设备 显示器 阴极射线管(CRT)显示器 字符显示器 图形显示器 图像显示器 打印机 小结 外存储器 磁盘存储器 磁盘设备的组成 存储区域 硬盘存储器 磁盘的性能指标 磁盘地址 硬 ...

  9. oracle使用rman备份集恢复方式创建ADG

    一.背景 系统: 主库:rhel 6.4 64bit 备库:rhel 6.4 64bit   内存:2G [oracle@dgdb1 ~]$ free -m total used free share ...

  10. IDEA 2020.3 更新了,机器学习都整上了

    Hello,大家好,我是楼下小黑哥~ 上周 Java 开发申请神器 IDEA 2020.3 新版正式发布: 小黑哥第一时间就在开发机上更新了新版本,并且完整体验了两周了. 下面介绍一下这个版本的主要功 ...