哈喽!大家好,我是小奇,一位热爱分享的程序员

小奇打算以轻松幽默的对话方式来分享一些技术,如果你觉得通过小奇的文章学到了东西,那就给小奇一个赞吧

文章持续更新

一、前言

书接上回,现在下着大雨看来是去不了镇上买熟食吃了,但是在家待着也没有意思,去找我表弟玩吧,看看他在家干啥呢?

表弟家离我家很近,走一条街再拐几个弯就到了,大中午的应该在家刚做完饭,正好蹭饭。

正要推开门发现门里面锁着呢,这大白天的锁着门干啥呢,敲了敲门。

我:有人在家吗?

表弟:谁呀?

我:我,你哥。

表弟:哦,那没有人在家,你回吧!

我:赶紧给我开门,别墨迹。

我说怎么这小子不开门,躲家里啃鸡腿呢,就怕我饭点来。

表弟:哥你咋来了?

我:咋?我还不能来啊!

表弟:你不是去北京找工作去了吗,怎么这么快就回来了。

我:别提了,现在工作不好找。

表弟:那不行你就回来跟我一起养猪吧,我老是出去卖猪肉,家里猪下崽了我也不能及时发现,你在家就能给我看着了。

我:现在哪里还用人看着猪圈啊,都是摄像头了。

表弟:啥是摄像头呢,去哪里找呢?

我:走,我带你去村里看看墙上刚打的广告。

表弟:说的真对,我现在就买一个。

我:你买吧,我回家做饭去了,你这就一个鸡腿还让你啃成这样子了,我走了。

回到家中做一个大米汤吧,炒一个蒜苔鸡蛋,正炒着菜呢电话响了。

我:“喂您好”。

对面:“您好,请问是小奇吗”。

我:“是我,你是?”。

对面:“我是XXX公司的,我看到hr推给我你的简历,我感觉还不错,你什么时候方便来现场面试一下”。

我:“现在不方便现场面试了”。

对面:“好吧,那你现在方便吗?我们现在线上面试一下吧”。

我:“好的”。

二、面试

面试官:我看你简历上写的精通Netty,那你能简单说一下Netty是什么吗?

我:Netty首先是一个java开源框架,他是一个提供了异步的、基于事件驱动的网络应用程序框架,所以说Netty就是一个网络应用框架,可以开发出高性能、高可靠的网络服务器和客户端程序。

面试官:嗯。那Netty为什么能够开发出高性能、高可靠的网络服务器呢,他为什么速度这么快呢?

我:这得益于Netty的线程模型的架构设计,使得Netty可以基于NIO的设计理念对线程模型基于改进,使得Netty在处理客户端请求连接,和客户端请求数据处理的时候可以快速的进行处理。

面试官:嗯。你能跟我分析一下Netty的线程模型吗?

我:Netty模型中首先有这些属性概念。

BossGroup:相当于一个事件循环线程池,这个池中有多个事件循环线程。这个线程池是专门处理客户端的连接事件的。

WorkerGroup:也是一个事件循环线程池,这个线程池是专门处理客户端的读写请求事件的。

NioEventLoop:这个就是事件循环线程,每一个事件循环线程都有一个selector用来监听事件。

NioSocketChannel:这个是在客户端与BossGroup中的一个事件循环线程建立连接后生成的,将这个可以注册到WorkerGroup的一个事件循环线程上,让WorkerGroup的事件线程来处理后续的读写请求。

Pipeline:这个处理从WorkerGroup过来的数据,他包含很多ChannelHandler,这些是真正处理数据的。

ChannelHandler:真正用来处理数据的。

面试官:嗯。可以讲一下从客户端连接到发送数据的整个流程吗?

1、客户端向BossGroup发起连接请求,BossGroup中的NioEventLoop处理了连接请求后生成一个NioSocketChannel。

2、BossGroup将NioSocketChannel注册到WorkerGroup中的一个NioEventLoop中的一个Selector上。至此BossGroup的工作完成,他接着处理其他客户端的连接请求。

3、WorkerGroup循环监听注册在自己的Selector上的这些NioSocketChannel有没有读写的事件发生。

4、WorkerGroup监听到NioSocketChannel有读写事件发生就交给Pipeline处理。至此WorkerGroup工作完成,他继续处理其他客户端的读写事件。

5、Pipeline接收到WorkerGroup发送过来的数据,然后交给ChannelHandler进行处理。

面试官:嗯。那Netty为什么比传统的网络编程工具更加快呢?

我:因为Netty将客户端的连接请求和读写数据的请求分开用两个线程池来处理,这样大大提高了效率。

面试官:“小伙子不错呀,什么时候能回北京入职呢”

我:“额。。。等等吧,现在家里雨太大了,容易弄一身巧克力。”

面试官:“行,那你来了北京一定来我们公司上班啊”

我:“额。。。这个跟你承诺不了,万一还有别的好公司给我打电话呢”。

面试官:“来吧,条件好商量”

我:“我考虑考虑吧”。

三、总结

这里的相关内容还没有整理完毕,文章后面持续更新,建议收藏。

文章中涉及到的命令大家一定要像我一样每个都敲几遍,只有在敲的过程中才能发现自己对命令是否真正的掌握了。

如果觉得我的文章还不错的话就点个赞吧

Netty是什么,Netty为什么速度这么快,线程模型分析的更多相关文章

  1. netty源码解解析(4.0)-4 线程模型-概览

    netty线程体系概览 netty的高并发能力很大程度上由它的线程模型决定的,netty定义了两种类型的线程: I/O线程: EventLoop, EventLoopGroup.一个EventLoop ...

  2. netty reactor线程模型分析

    netty4线程模型 ServerBootstrap http示例 // Configure the server. EventLoopGroup bossGroup = new EpollEvent ...

  3. netty源码解解析(4.0)-7 线程模型-IO线程EventLoopGroup和NIO实现(二)

    把NIO事件转换成对channel unsafe的调用或NioTask的调用 processSelectedKeys()方法是处理NIO事件的入口: private void processSelec ...

  4. netty源码解解析(4.0)-6 线程模型-IO线程EventLoopGroup和NIO实现(一)

    接口定义 io.netty.channel.EventLoopGroup extends EventExecutorGroup 方法 说明 ChannelFuture register(Channel ...

  5. netty源码解解析(4.0)-5 线程模型-EventExecutorGroup框架

    上一章讲了EventExecutorGroup的整体结构和原理,这一章我们来探究一下它的具体实现. EventExecutorGroup和EventExecutor接口 io.netty.util.c ...

  6. Netty In Action中文版 - 第十五章:选择正确的线程模型

    http://blog.csdn.net/abc_key/article/details/38419469 本章介绍 线程模型(thread-model) 事件循环(EventLoop) 并发(Con ...

  7. 性能追击:万字长文30+图揭秘8大主流服务器程序线程模型 | Node.js,Apache,Nginx,Netty,Redis,Tomcat,MySQL,Zuul

    本文为<高性能网络编程游记>的第六篇"性能追击:万字长文30+图揭秘8大主流服务器程序线程模型". 最近拍的照片比较少,不知道配什么图好,于是自己画了一个,凑合着用,让 ...

  8. [Netty 1] 初识Netty

    1. 简介 最早接触netty是在阅读Zookeeper源码的时候,后来看到Storm的消息传输层也由ZMQ转为Netty,所以决心好好来研究和学习一下netty这个框架. Netty项目地址:htt ...

  9. Netty高性能之Reactor线程模型

    Netty是一个高性能.异步事件驱动的NIO框架,它提供了对TCP.UDP和文件传输的支持,作为一个异步NIO框架,Netty的所有IO操作都是异步非阻塞的,通过Future-Listener机制,用 ...

随机推荐

  1. 世界各国 MCC 和 MNC 列表

    http://www.cnblogs.com/inteliot/archive/2012/08/22/2651666.html常见MCC:代码(MCC)    ISO 3166-1    国家202 ...

  2. PAT B1015德才论

    题目描述: 宋代史学家司马光在<资治通鉴>中有一段著名的"德才论":"是故才德全尽谓之圣人,才德兼亡谓之愚人,德胜才谓之君子,才胜德谓之小人.凡取人之术,苟不 ...

  3. 将PHPMailer整合到ThinkPHP 3.2 中实现SMTP发送邮件

    本内容转载出处:http://my.oschina.net/BearCatYN/blog/299192 并对以下内容做了一处说明. ThinkPHP没有邮件发送的功能,于是,我就想了想,就将PHPMa ...

  4. dotnet new 命令笔记

    让dotnet new使用平台特定的目标,例如net6.0-windows10.0.19041.0 dotnet new console --name CallWinRTConsole --frame ...

  5. git概述

    学习资料来源-人家写得比我好 #视频教程: https://www.bilibili.com/video/BV1vy4y1s7k6?spm_id_from=pageDriver #文档教程 https ...

  6. go sync.map源码解析

    go中的map是并发不安全的,同时多个协程读取不会出现问题,但是多个协程 同时读写就会出现 fatal error:concurrent map read and map write的错误.通用的解决 ...

  7. Asynchronous Methods for Deep Reinforcement Learning

    郑重声明:原文参见标题,如有侵权,请联系作者,将会撤销发布! ICML 2016 Abstract 我们提出了一个概念上简单且轻量级的深度强化学习框架,该框架使用异步梯度下降来优化深度神经网络控制器. ...

  8. jsp第二周作业

    1.p39 实验2 显示当前时间,并输出上午(0-12)好,下午好(13-17),晚上好(18-23) <%@ page language="java" import=&qu ...

  9. 聊一聊Redis的离线分析

    背景 Redis 或许是我们大部分场景都会用到的一个利器,虽然是利器,用的姿势不对的话,终究还是会整出幺蛾子的. 比较常见的问题,不外乎内存暴增,慢查询等情况. 那么对于内存问题,可以借助redis自 ...

  10. marginStart marginEnd就关于上述两个用法展开讨论

    在我还在手动调整两个控件距离时,第一次见识到了marginStart marginEnd两个用法, 但是,只知道它俩能够调整控件距离,但是不知道具体用法,老师也没细说,就这样开启了我对于这两个用法&q ...