zoukankan      html  css  js  c++  java
  • 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)

  • 相关阅读:
    第三次作业
    第二次作业
    第一次作业
    仪仗队(欧拉函数)
    自己随便做的,没做完就没耐心继续了。呵呵
    从别处见到一位大神的代码 飞扬的小鸟(flappy bird)
    简易迷宫游戏c++
    STL做法 平衡树
    基于百度地图api + AngularJS 的入门地图
    javascript 简易文本编辑器
  • 原文地址:https://www.cnblogs.com/windghost/p/13163907.html
Copyright © 2011-2022 走看看