zoukankan      html  css  js  c++  java
  • (一)Mina源代码解析之总体架构

            Apache Mina Server 是一个网络通信应用框架。也就是说,它主要是对基于TCP/IP、UDP/IP协议栈的通信框架(当然,也能够提供JAVA 对象的序列化服务、虚拟机管道通信服务等)。Mina 能够帮助我们高速开发高性能、高扩展性的网络通信应用,Mina 提供了事件驱动、异步(Mina 的异步IO 默认使用的是JAVA NIO 作为底层支持)操作的编程模型。

            Mina 同一时候提供了网络通信的Server 端、Client 端的封装。不管是哪端,Mina 在整个网通通信结构中都处于例如以下的位置:

    Mina的内部结构例如以下:

    上图中,我们能够非常明显的看出,基于mina的应用被分成3层

    第一层I/O Service:处理真实的I/O

    第二层I/O FilterChain:过滤盒传输字节流成指定的数据结构

    第三层I/O Handler:处理真实的业务逻辑

    server结构:

    server在我们指定的port监听请求。处理请求发送应答信息,当我们使用TCP和UDP传输协议时它还会为每一个client创建和处理session


    IoAcceptor监听是否有连接或数据包的到来。对于一个新的连接。一个新的session会被创建随后全部的从这个IPport的请求会被在这个session中处理,从session中接收的全部数据包会横穿FilterChain 。Filter能够用来改动数据包的内容,比如将字节流转化成Object,我们还能够通过自己定义的编解码器将字节流转化成我们指定的不论什么类型,终于数据包或Object会到达IoHandler,IoHandler用来处理我们的业务逻辑

    Client结构

    client须要连接server,发送消息处理应答

    client第一次创建IoConnector,初始化和server的连接。一个session会被创建然后和这个连接绑定,client向这个session中写入数据,穿过过滤器链然后发送给server。全部从这个server接收的应答穿过过滤器链来到IoHandler,进行业务逻辑处理



  • 相关阅读:
    模拟死锁
    B站学习斯坦福大学Swift 语言教程 iOS11 开发【第一集】踩到的几个坑(XCode 13.2.1版本)
    数学之美番外篇:平凡而又神奇的贝叶斯方法
    joj 1753: Street Numbers
    二叉树的三种遍历(递归+非递归)
    joj 1905: Freckles
    joj 2630: A Pair of Graphs(同构图的判定)
    vue3.x 中获取dom元素
    defineProperty 和 Proxy 的区别
    vue 按钮的防抖和节流
  • 原文地址:https://www.cnblogs.com/claireyuancy/p/7275635.html
Copyright © 2011-2022 走看看