OpenHarmony源码分析之分布式软总线:trans_service模块(4)/TCP会话管理

一、概述

trans_service模块基于系统内核提供的socket通信,向authmanager模块提供设备认证通道管理和设备认证数据的传输;向业务模块提供session管理和基于session的数据收发功能,并且通过GCM模块的加密功能提供收发报文的加解密保护。 在上一篇博客 OpenHarmony源码分析之分布式软总线:trans_service模块(2)/会话管理之新会话 中已经介绍了在分布式软总线中TCP会话管理的部分内容,如TCP新会话的管理。本文将继续介绍会话管理的相关内容,重点在于TCP会话中的通信数据管理。

二、源码分析

  1. 在函数ProcessData(),根据套接字fd的状态判断是有新的连接请求,还是有新的数据到达,在之前的博客中已经介绍了前一种可能,接下来我们一起来看一下有新数据到达时,系统如何进行处理。在函数ProcessData()中:
scss 复制代码
/*
函数功能:处理新数据或者新连接
函数参数:
    tsm:会话管理器地址
    rfds:可读描述符集合
函数返回值:无
详细:
*/
static void ProcessData(TcpSessionMgr *tsm, fd_set *rfds)
{
    if (tsm == NULL || tsm->listenFd == -1) {
        return;
    }
    if (FD_ISSET(tsm->listenFd, rfds)) {//新连接到达
        ProcessConnection(tsm);//处理新会话连接事件
        return;
    }
    ProcessSesssionData(tsm, rfds);//处理tcp会话中的新数据到达事件
}
  1. 调用ProcessSesssionData()函数处理新数据。轮询会话管理器中每个会话的fd,看是否有数据到达。
rust 复制代码
/*
函数功能:处理每个会话的新数据
函数参数:
    tsm:会话管理器地址
    rfds:可读描述符集合
函数返回值:无
详细:
*/
static void ProcessSesssionData(const TcpSessionMgr *tsm, const fd_set *rfds)
{
    for (int i = 0; i < MAX_SESSION_SUM_NUM; i++) {
        if (tsm->sessionMap_[i] != NULL && tsm->sessionMap_[i]->fd != -1 &&
            FD_ISSET(tsm->sessionMap_[i]->fd, rfds) > 0) {//轮询每个会话的fd,看是否有数据到达
            if (!OnProcessDataAvailable(tsm->sessionMap_[i])) {//处理每个会话的新数据
                return;
            }
        }
    }
}

DD一下: 欢迎大家关注公众号<程序猿百晓生>,可以了解到一下知识点。

erlang 复制代码
1.OpenHarmony开发基础
2.OpenHarmony北向开发环境搭建
3.鸿蒙南向开发环境的搭建
4.鸿蒙生态应用开发白皮书V2.0 & V3.0
5.鸿蒙开发面试真题(含参考答案) 
6.TypeScript入门学习手册
7.OpenHarmony 经典面试题(含参考答案)
8.OpenHarmony设备开发入门【最新版】
9.沉浸式剖析OpenHarmony源代码
10.系统定制指南
11.【OpenHarmony】Uboot 驱动加载流程
12.OpenHarmony构建系统--GN与子系统、部件、模块详解
13.ohos开机init启动流程
14.鸿蒙版性能优化指南
.......
  1. 紧接着在函数OnProcessDataAvailable()中处理每个会话的新数据。
arduino 复制代码
/*
函数功能:处理会话中新到达的数据
函数参数:
    session:tcp会话地址
函数返回值:
    成功:返回true
    失败:返回false
详细:
*/
static bool OnProcessDataAvailable(TcpSession *session)
{
    if (session == NULL) {
        return false;
    }
    if (strcmp(session->sessionName, "softbus_Lite_unknown") == 0) {//如果会话名称是默认名称,即是未知设备,表示这是一个新会话
        bool isSuccess = HandleRequestMsg(session);//处理请求消息
        if (!isSuccess) {
            CloseSession(session->fd);
        }
        return isSuccess;
    } else {
        unsigned char* buf = calloc(1, RECIVED_BUFF_SIZE);
        if (buf == NULL) {
            return false;
        }
        SOFTBUS_PRINT("[TRANS] OnProcessDataAvailable sessionName: %s, fd: %d\n", session->sessionName, session->fd);
        SessionListenerMap *sessionListener = GetSessionListenerByName(session->sessionName,
            strlen(session->sessionName));//根据会话名字在会话管理器的会话监听器表中查找相应会话监听器
        if (sessionListener != NULL && sessionListener->listener != NULL) {//若会话监听器已存在,则表明该会话已创建
            int recvLen = TcpSessionRecv(session, (char *)buf, RECIVED_BUFF_SIZE, 0);//接收会话新数据并进行解密,返回明文数据
            if (recvLen < 0) {
                free(buf);
                return false;
            }
            sessionListener->listener->onBytesReceived(session->fd, buf, recvLen);//通知会话监听器,数据已收到
            free(buf);
            return true;
        }
        free(buf);
    }
    return false;
}

具体的处理过程将在下一篇博客中详细介绍,未完待续。

相关推荐
Bruce_Liuxiaowei1 小时前
HarmonyOS Next~鸿蒙系统UI创新实践:原生精致理念下的设计革命
ui·华为·harmonyos
青铜爱码士3 小时前
redis+lua+固定窗口实现分布式限流
redis·分布式·lua
啊喜拔牙5 小时前
如何搭建spark yarn模式的集群
大数据·分布式·spark
听雨·眠5 小时前
关于kafka
分布式·kafka·消息队列
TE-茶叶蛋5 小时前
NestJS + Kafka 秒杀系统完整实践总结
分布式·kafka
SuperHeroWu76 小时前
【HarmonyOS 5】鸿蒙检测系统完整性
华为·harmonyos·模拟器·系统完整性·越狱设备
慧一居士6 小时前
Kafka批量消费部分处理成功时的手动提交方案
分布式·后端·kafka
京东云开发者7 小时前
Taro on Harmony :助力业务高效开发纯血鸿蒙应用
harmonyos
搞不懂语言的程序员7 小时前
如何实现Kafka的Exactly-Once语义?
分布式·kafka·linq
ErizJ7 小时前
Golang|分布式索引架构
开发语言·分布式·后端·架构·golang