流程描述

我们从bind函数开始:
1、首先创建了两个NioEventLoopGroup,这是初始化了两个线程组,这两个线程组根据命名可以知道一个是bossGroup,是服务器用来接收客户端的请求的,另一个是workGroup是用来处理NioServerSocketChannel的网络读写的。这两个线程组实际承担的是一个Reactor的角色。
2、第二步就是初始化一个ServerBootstrap,这是Netty用于启动NIO服务端的辅助启动类,目的是降低服务器开发的复杂度。ServerBootstrap的初始化首先是调用group方法,将两个线程组作为参数传到ServerBootstrap中。接着创建channel为NioServerSocketChannel。然后调用option配置channel的TCP参数,其中SO_BACKLOG设置为1024的意思是服务器监听队列的大小是1024,最后设置处理IO事件的处理器ChildChannelHandler,它的作用类似于Rector模式中的handler用来处理IO事件。
3、启动类初始化完成后调用ServerBootstrap的bind方法绑定端口,监听请求,在调用sync等待绑定完成。完成之后返回一个ChannelFuture作用是用于异步操作的通知回调。
4、调用 future.channel().closeFuture().sync进行阻塞,等待服务端链路关闭main函数退出。
5、调用EventLoopGroup的shutdownGracefully方法,释放相关的资源。

Netty的线程模型

netty是一个高可用的基于事件驱动的异步的NIO框架,核心的线程模型是Reactor,Reactor线程模型有单线程Reactor,多线程Reactor和多线程主从复制的Reactor,这里我们就用最简单的单线程Reactor来分析下Netty的线程模型,进而来看Netty的相关核心类在此模型下扮演的角色和作用。
在网络交互中,无论你是建立连接进行通信还是数据的读写都是继续网络通信协议的,底层就是TCP/IP协议栈,协议栈是操作系统层的,我们无法修改他的协议栈,但是操作系统给了我们可以操作和使用协议栈的接口,比如我们经常使用的bind、accept、connect等,而这写操作的本身,我们都是对socket的操作,所以我们可以任务一个socket,就是用户跟TCP/IP协议栈进行交互的门户。

传统的IO

一请求一应答,这是BIO。每次读写都需要生成新的线程,请求多的时候占用大量的线程资源。高并发的情况下很可能造成巨大的线上故障。

NIO Reactor模型

socket注册到Selector中,由Selector决策哪个事件可以执行。

Netty的线程模型

服务器的线程模型为例:

抽象出NioEventLoop来表示一个不断循环执行处理任务的线程,每个NioEventLoop有一个selector,用于监听绑定在其上的socket链路。服务端维护了两个EventLoopGroup,一个bossGroup,一个workGroup,bossGroup用来处理客户端的连接请求,然后打开Channel,把这个Channel交给workGroup中的一个EventLoop被注册来处理该Channel上的所有请求。一个Channel只会被一个workGroup处理,一个workGroup可以同时被多个Channel使用。
简单了解了Netty的一个线程模型,我们来看看netty编程中那些核心类的作用。

Netty架构

核心类分析

EventLoop

EventLoop是Netty中极其重要的组件,翻译为时间循环,一个EventLoop被分配给Channel来负责这个Cahnnel上的所有事件。EventLoop你可以理解为一个线程,EventLoopGroup是一个线程池,EventLoopGroup继承ScheduledExecutorService,也就是调度线程池,理论上EventLoopGroup应该具有ScheduledExecutorService的所有的功能,之所以叫做事件循环,我猜想它必然有一个循环把Cahnnel上面准备就绪的事件提交给一个Thread来处理。这个实现在SingleThreadEventLoop的一个继承类EpollEventLoop中的run方法实现

总结

如果你选择了IT行业并坚定的走下去,这个方向肯定是没有一丝问题的,这是个高薪行业,但是高薪是凭自己的努力学习获取来的,这次我把P8大佬用过的一些学习笔记(pdf)都整理在本文中了,如果你有需要的话,请一定点赞分享本文,然后点击这里获取免费下载方式!

《Java中高级核心知识全面解析》

小米商场项目实战,别再担心面试没有实战项目:

mg-KtMSeCfJ-1624778733580)]

小米商场项目实战,别再担心面试没有实战项目:

java文档注释用什么开头,极其重要相关推荐

  1. Java文档注释用法+JavaDoc的使用详解

    Java文档注释+JavaDoc的使用详解 简介 文档注释负责描述类.接口.方法.构造器.成员属性.可以被JDK提供的工具 javadoc 所解析,自动生成一套以网页文件形式体现该程序说明文档的注释. ...

  2. java文档注释 编写格式

    java 文档注释 在sun主页上有java文档注释的编写格式 How to Write Doc Comments for the Javadoc Tool http://java.sun.com/j ...

  3. IDEA JAVA文档注释和方法注释模板

    IDEA JAVA文档注释和方法注释模板 文档注释 #if (${PACKAGE_NAME} && ${PACKAGE_NAME} != "")package ${ ...

  4. java文档注释报错,java文档注释主要使用方法

    一.java包含哪些注释 1.//用于单行注释. 2./*...*/用于多行注释,从/*开始,到*/结束,不能嵌套. 3./**...*/则是为支持jdk工具javadoc.exe而特有的注释语句.这 ...

  5. Java注释详解-Java文档注释生成Java API文档

    Java文档注释是一种功能强大的注释形式,如果在你所编写的程序中规范的添加文档注释,那你就可以生成一份系统正规的API文档.Java文档注释 /**文档注释内容*/,注意区分多行注释/*多行注释*/. ...

  6. 如何写Java文档注释(Java Doc Comments)

    本文翻译自How to Write Doc Comments for the Javadoc Tool,但是精简了一些私以为不重要的东西 本文不讨论如何使用javadoc工具自动生成文档的方法,而是主 ...

  7. java文档注释详解

    https://blog.csdn.net/houhj168/article/details/41146415 对于Java语言,最体贴的一项设计就是它并没有打算让人们为了写程序而写程序--人们也需要 ...

  8. Java文档注释【自制API】

    工具类的文档注释 工具类:一般都定义成静态的,只提供工具方法,没有特定数据,不需要构建对象. 为了保证不让其他成员创建对象,将无参的构造函数设置为私有化即可. 源文件: @author 作者 @ver ...

  9. java文档注释生产api没有注释_如何使用javadoc命令生成api文档,文档注释

    /** * 计算器工具类 * * @62616964757a686964616fe78988e69d8331333365646332author GaoHuanjie * @version V1.0 ...

最新文章

  1. 小米手机 DELETE_FAILED_INTERNAL_ERROR Error while Installing APKs
  2. 合适么?现在学ASP.NET Core入门编程……
  3. 设置 Linux 的 LD_LIBRARY_PATH 变量
  4. python requests session刷新_Python Requests Session set-cookie不生效的坑
  5. 数据分析师能用到mysql_浅谈数据分析师的必备技能SQL
  6. Vue3传值(一) props: 父组件向子组件传值
  7. 物联网(IoT)会是广告欺诈的一道后门
  8. (转)深入理解Java的接口和抽象类
  9. Mapreduce运行过程分析(基于Hadoop2.4)——(三)
  10. 检测目标程序ELF bit是32还是64
  11. 2020腾讯秋招笔试编程题--压缩算法
  12. ProcessOn 在线作图,真香指南
  13. 第十届全国大学生GIS应用技能大赛上午(试题及参考答案)
  14. A cycle was detected in the build path of project 'core'. The cycle consists of projects {core, sms}
  15. POI设置Excel下拉列表(数据有效性验证)
  16. android仿微信发送位置,Android仿微信发送位置-百度地图
  17. Maven传递依赖的时候,同名包不同版本的包均会下载,但是编译的时候,只会加载一个高版本的。
  18. 程序设计大作业---超长正整数的减法
  19. php mysql 排班表_要做排班表 灵活性比较强的
  20. QT使用多国语言及linguist工具使用

热门文章

  1. FPGA接口-PMOD,FMC与SYZYGY
  2. 百度人脸产品套件开箱体验-壁虎开机初体验
  3. mysql jail_ubuntu – 为chrooted jail设置PHP / MYSQL(jailkit)
  4. 人工智能换脸pythonapp_如何用小200行Python代码做一个换脸程序?
  5. Holoview--Introduction
  6. NestJs 学习(一) 基础知识
  7. 南京大学软件工程842参考书攻略
  8. 香港服务器 微信支付,如何给微信开通香港钱包(WeChat Pay HK)
  9. 哥伦比亚大学 NLP 第三章(第二部分)
  10. 一文看懂Linux内核的整体架构