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;
}

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

相关推荐
ZePingPingZe2 小时前
秒杀-库存超卖&流量削峰
java·分布式
Wang's Blog3 小时前
Kafka: HTTPS证书申请集成指南
分布式·https·kafka
天聚数行3 小时前
华为鸿蒙系统(HarmonyOS)调用天聚数行 API 教程
华为·php·harmonyos·tianapi·天聚数行
BlackWolfSky4 小时前
鸿蒙加解密
华为·harmonyos
融云4 小时前
融云 4 款 SDK 首批通过 GIIC 鸿蒙生态评测
华为·harmonyos
月光技术杂谈5 小时前
Linux发展到6.0了,其在嵌入式应用中,实时性方面有没有一些改进?
linux·嵌入式·实时性
讯方洋哥5 小时前
HarmonyOS应用开发—页面路由
华为·harmonyos
鸿蒙开发工程师—阿辉5 小时前
HarmonyOS 5 高效使用命令:HDC 基本使用
华为·harmonyos
Wang's Blog6 小时前
Kafka: 消费者高级实践之分区控制、多线程处理与 Offset 管理
分布式·kafka
梧桐ty6 小时前
鸿蒙 + Flutter:构建万物互联时代的跨平台应用新范式
flutter·华为·harmonyos