221 netty模型相关

0、一些代码内容ServerBootstrap(group、channel) EventLoopGroup ChannelFuture

 

1、 reactor模型相关实现:

  客户端请求-->reactor线程(eventloopselector做事件轮训-->dispatcher分发)  --->处理方法

netty启动时会构建多个EventloopGroup(reactor线程)

 

2、pipeline 责任链相关

   责任链: 可以认为是责任递进的链条(集合形式、链表形式)。包含:处理器抽象类、处理器实现、保存处理器信息(下个节点)、处理执行

    registered入栈时间处理:bind端口abstractBootStrap--》创建和初始化channel--》注册eventLoop到selector上(config group register后 触发channel注册) ps 初始化handler仅执行一次

                                             注册完成后 省下 headcontext loggingHandler ServerBootstrapAcceptor  tailcontext

   bind 出站事件处理 bind(端口):abstractBootstrap  ->创建和初始化channel -> 注册到eventloop的selector上 ->channelbind -> pipelinebind

 

   accept入栈事件的处理:Eventloop轮询到accept事件-》nioMessageUnsafe.read

3、bytebuf

     容量(可以动态扩容)、读取位置、写入位置----已读取区域,可读取区域、待写区域

     实现方式:堆内堆外、是否池化、访问方式(safe,unsafe)

posted on   李某人的窥视  阅读(103)  评论(0编辑  收藏  举报

编辑推荐:
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
阅读排行:
· PowerShell开发游戏 · 打蜜蜂
· 在鹅厂做java开发是什么体验
· 百万级群聊的设计实践
· WPF到Web的无缝过渡:英雄联盟客户端的OpenSilver迁移实战
· 永远不要相信用户的输入:从 SQL 注入攻防看输入验证的重要性

导航

< 2025年2月 >
26 27 28 29 30 31 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 1
2 3 4 5 6 7 8

统计

点击右上角即可分享
微信分享提示