zoukankan      html  css  js  c++  java
  • 中转server

    中转传输概要设计

    中转传输的消息架构为模拟MFC的消息架构,请參考我的上一篇文章。

    1. 概述

    中转server採用事件驱动的方式,与socket结合。其层次例如以下:

     

    在事件驱动层中,将相关消息发送给相应的用户事件处理函数处理。

    在命令解析层中发送和接收数据。在接收到数据时,须要验证数据合法性,收到一帧完整的数据后调用消息驱动层的send相关方法,调用该类方法后会将消息传递给用户事件处理中。

    在命令解析层中,会引入socket控制,同一时候管理多个socket的读。

    在用户事件处理中,须要像MFC那样,定义消息处理的映射表。仅仅有在用户层定义了消息映射表,命令解析层接收到的命令才干被处理,否则被丢弃。


    2. 事件驱动层

    消息分两种:post类消息和Send类消息。

    Post类消息首先须要将消息放入消息列表中,由消息处理线程负责派发消息,所以消息的发送与处理是异步的。

    Send类消息不须要经过消息列表,直接由send相关方法派发消息,所以仅仅有等待消息被处理完毕send方法才返回。

    post事件驱动流程图:

    事件驱动贯穿整个流程,一般事件驱动流程退出,则程序退出。

    2.1 事件信息

    事件分为例如以下两种:

    a. 整型事件,用一个整型数字标志一个事件,该事件參考MFC的基本结构;

    b. 字符串事件,以命令的形式定义一个事件;

    事件目标:

    事件目标能够是目标的直接handle,也能够是目标的名称。

    2.2 基本事件

    我们规定在1024以内的整型事件为基本事件,由事件驱动层定义。用户能够定义不论什么大于1024的事件,不同对象之间事件号能够反复。


    3. Socket控制


    socket控制中,主要监控socket的读和异常状态。对于写上层能够直接调用send发送数据。 

    外部假设须要释放已经放入到控制列表的sokcet,必须调用控制层的接口。


    4. 用户事件处理

    时序图例如以下:


    登录、心跳和退出流程

    转发文件流程图


  • 相关阅读:
    【转载】中文分词整理
    【转载】浅谈事件冒泡与事件捕获
    【转载】SpringCloud-Eurek 心跳阈值说明
    【转载】Linux下查看CPU、内存占用率
    Linux内存、性能诊断中vmstat命令的详解
    【转载】springboot四 全局异常处理
    【转载】linux系统时间自动同步:ntp
    springboot整合三 共享session,集成springsession
    git把一个分支上的某个提交合并到另一个分支
    VS Code打开新的文件会覆盖窗口中的,怎么改
  • 原文地址:https://www.cnblogs.com/bhlsheji/p/4269356.html
Copyright © 2011-2022 走看看