`
Poechant
  • 浏览: 229610 次
博客专栏
Bebe66e7-3a30-3fc9-aeea-cfa3b474b591
Nginx高性能Web服务...
浏览量:24328
5738817b-23a1-3a32-86de-632d7da73b1e
Cumulus实时媒体服务...
浏览量:22104
社区版块
存档分类
最新评论

OpenRTMFP/Cumulus Primer(19)独立使用CumulusLib时的线程安全Bug

 
阅读更多

OpenRTMFP/Cumulus Primer(19)独立使用CumulusLib时的线程安全Bug

  • 作者:柳大·Poechant(钟超)
  • 邮箱:zhongchao.ustc#gmail.com(# -> @)
  • 博客:Blog.CSDN.net/Poechant
  • 日期:June 7nd, 2012

OpenRTMFP/Cumulus 提供了 CumulusLib 可以供其他 RTMFP 应用使用,而不局限于 CumulusServer。

一般来说,Thread A 会准备好要 push 的消息,然后 Thread A 向消息队列 push 消息。

但是 CumulusLib 中实现的,是 Thread A 向消息队列 push 消息,然后根据这个消息在队列中的指针,再向消息内填写字段。并期望如下:

Resize icon

由于在 CumulusServer 中,一个 Client 只在一个线程内被操作,相应的 FlowWriter 也不会出现跨线程的问题。但是如果单独使用 CumulusLib,如果出现线程通信,并且共享 FlowWriter 的话,就会共享消息队列,此时可能出现这种情况。

Resize icon

这就导致了很严重的错误,会使得进程崩溃。修正的方式,可以是将消息完全准备好之后,再放入队列,如下:

/*
 * author:  michael
 * date:    June 6th, 2012
 * type:    add
 */
MessageBuffered* FlowWriter::createAMFMessage(const std::string& name)

    // signature.empty() means that we are on the flowWriter of FlowNull
    if (!(_closed || signature.empty() || _band.failed())) {
        MessageBuffered* pMessage = new MessageBuffered();
        MessageBuffered& message(*pMessage);
        writeResponseHeader(message.rawWriter,name,0);
        return pMessage;
    }

    MessageBuffered& message(_MessageNull);
    writeResponseHeader(message.rawWriter,name,0);
    return NULL;
}

然后再调用时最后再增加 push 操作:

/*
 * author:  michael
 * date:    June 6th, 2012
 * type:    add
 */
void FlowWriter::pushAMFMessage(MessageBuffered* pMessage) {
    if (pMessage != NULL) {
        _messages.push_back(pMessage);
    }
}

这样就使得消息的数据被写完了,才被放入队列中,如下:

Resize icon

不过如果考虑线程安全,多个线程对同一个消息队列进行操作时,就要加锁:

/*
 * author:  michael
 * date:    June 6th, 2012
 * type:    add
 */
void FlowWriter::pushAMFMessage(MessageBuffered* pMessage) {
    if (pMessage != NULL) {
        Poco::Mutex::ScopedLock lock(msgQueueMutex);
        _messages.push_back(pMessage);
    }
}

这样就基本解决了这个线程安全问题。

另外,使用 CumulusLib 要遵循 GPL 协议,一定不要忘记。

-

转载请注明来自柳大·Poechant(钟超)的CSDN博客:Blog.CSDN.net/Poechant

-

分享到:
评论

相关推荐

    OpenRTMFP Cumulus Primer()入门介绍与部署CumulusServer.pdf

    1. 在OpenRTMFP-Cumulus/CumulusLib目录下运行`make`。 2. 然后转到OpenRTMFP-Cumulus/CumulusServer目录,再次运行`make`。 如果在编译过程中遇到头文件或库文件找不到的问题,你需要检查Makefile,确保路径设置...

    cumulus(浑天仪)使用手册

    在使用Cumulus时,首先需要理解其基本架构和工作流程。这可能包括设置项目、导入数据、配置标签系统等步骤。对于源码爱好者,阅读和理解Cumulus的源码可以深入了解其内部逻辑,学习如何构建类似的工具。对于普通用户...

    cumulus-linux-4.4.0-vx-amd64-qemu.zip

    6. **QEMU虚拟化**:通过使用“cumulus-linux-4.4.0-vx-amd64-qemu.qcow2”镜像,用户可以在本地或者云环境中快速搭建一个Cumulus Linux的仿真环境,进行功能测试、学习或开发验证,而无需物理硬件。 7. **EVE环境*...

    wp-cumulus(支持中文标签)

    **wp-cumulus插件详解** `wp-cumulus`是一款专门为WordPress博客设计的炫酷三维标签云插件。这款插件以其独特的视觉效果和良好的用户体验,在众多的WordPress标签云插件中脱颖而出。通过使用`wp-cumulus`,用户可以...

    HPCCloud:基于 CloudWeb 的仿真环境

    高性能计算云 目标 ...$ vi /opt/hpccloud/cumulus/cumulus/conf/config.json +- > Fix host to be localhost +- > baseUrl: " http://localhost:8080/api/v1 " , $ sudo service celeryd restar

    cumulus-linux-cookbook:用于管理积云开关的手册

    这本食谱在 vanilla Debian 上创建了一个交换机覆盖,并且还部署在 Cumulus 路由器/交换机上。 要求 测试 访问 Debian Wheezy 盒子 生产 访问 Cumulus HCL [1] 开关(Accton AS6701_32X,这就是这本食谱最初的目的)...

    wp-cumulus

    在使用过程中,确保你的网站已经安装了Flash插件,因为"wp-cumulus" 在运行时需要依赖Flash支持。不过,随着HTML5技术的发展,一些现代版本可能提供了HTML5替代方案,以便在不支持Flash的设备上也能正常显示。 总的...

    Flex P2P 音视频流客户端(Cumulus支持)

    使用Cumulus,开发者可以创建具有音视频流功能的应用程序,例如视频会议、在线教育平台、多人游戏等。Cumulus库不仅实现了OpenRTMFP协议,还提供了一套灵活的API,使得开发者能够方便地控制和管理P2P连接。 在...

    wp-cumulus_3D云标签

    《WordPress中的wp-cumulus 3D云标签详解》 在WordPress这个强大的开源博客平台中,wp-cumulus是一款极具特色的3D云标签插件。它以其独特的视觉效果和交互体验,为用户提供了全新的标签展示方式,使得博客的分类和...

    Cumulus:一个基于网络编码的分布式文件系统.pdf

    【 Cumulus:基于网络编码的分布式文件系统 】 在分布式计算领域,分布式文件系统是支撑大规模数据处理和存储的关键技术之一。Cumulus 是一个创新性的分布式文件系统,它利用网络编码理论来优化系统的容错能力和...

    Cumulus官网视频会议样例代码

    这里给出了cumulus/OpenRTMFP的git官网提到的视频会话样例的AS3代码,包括服务器端和客户端两部分,我已经在<使用Cumulus和Flash Player搭建视频会议示例>http://blog.csdn.net/tao_627/article/details/18041473中给...

    Mellanox Cumulus 培训资源

    Mellanox Cumulus学习,基本使用,培训资源

    RTMFP服务器脚本CumulusServer.zip

    openrtmfp又名Cumulus Server是一个完全开源和跨平台的可扩展的RTMFP服务器脚本。Cumulus Server在GPL 框架下遵循速度、优势、跨平台、轻量和高质量代码。Cumulus Server的每一个版本都是通过严格测试和审核的。可...

    Cumulus:CloudApp 的开源替代品,利用您自己的 S3 进行存储

    积云Cumulus 是的免费、开源替代品,它利用您自己的 S3 进行存储。下载您可以在下载最新版本更改默认截图目录这是可选的。 默认情况下,OS X 会将屏幕截图放在您的桌面上。 但是,如果您希望他们去其他地方,您可以...

    cumulus:Cumulus框架+ Cumulus API

    积云框架 :open_book: 文献资料 最新文档。 文档。 更多信息 有关此项目的更多信息,以及有关NASA的地球观测系统数据和信息系统(EOSDIS)及其云工作的更多信息,请联系或访问 。...这是用于Cumulus开

    cumulus-integration-tests:Cumulus工作流的集成测试[已弃用]

    Cumulus集成测试项目[已弃用] ... 运行测试时,默认情况下,测试将使用spec/config.yml定义的配置来尝试执行工作流程。 这些变量是在CircleCI上运行测试所必需的。 可以在您自己的spec/config.override

    wp-cumulus.rar_TagCloud._TagCloud.as_flex cumul_wp cumulus_wp cu

    【描述】"完美支持中文wp-cumulus插件源码(无锯齿无抖动7K大小)"说明这个插件是为中文环境优化的,解决了在显示中文标签时可能出现的锯齿或抖动问题,同时强调了其源代码的轻量化,只有7K大小,意味着它在加载和...

    3D标签云单机中文版 WP-CUMULUS 1.23

    大名鼎鼎的WP-CUMULUS 3D标签云,已经改成支持中文标签,可在.htm自行添加标签链接,可以单机玩耍测试,不需要安装WordPress然后装插件~~ 主要是有些童鞋只是想要3D标签云动画,所以就提取重要文件出来稍作修改下.

    Python库 | cumulus-1.1.0.tar.gz

    Python库是开发者在编程时经常会使用到的重要工具,它们提供了丰富的功能,可以帮助程序员高效地完成各种任务。在本文中,我们将深入探讨名为“cumulus”的Python库,版本为1.1.0,它以tar.gz格式进行压缩。这个库...

    drupal -cumulus

    Drupal 是一个广泛使用的开源内容管理系统(CMS),它允许用户创建和管理复杂的网站。在这个特定的场景中,我们关注的是 Drupal 的两个模块:Tagadelic 和 Cumulus,它们都是用来实现标签云(Tag Cloud)效果的。 ...

Global site tag (gtag.js) - Google Analytics