OpenRTMFP/Cumulus Primer(19)独立使用CumulusLib时的线程安全Bug
OpenRTMFP/Cumulus 提供了 CumulusLib 可以供其他 RTMFP 应用使用,而不局限于 CumulusServer。
一般来说,Thread A 会准备好要 push 的消息,然后 Thread A 向消息队列 push 消息。
但是 CumulusLib 中实现的,是 Thread A 向消息队列 push 消息,然后根据这个消息在队列中的指针,再向消息内填写字段。并期望如下:
由于在 CumulusServer 中,一个 Client 只在一个线程内被操作,相应的 FlowWriter 也不会出现跨线程的问题。但是如果单独使用 CumulusLib,如果出现线程通信,并且共享 FlowWriter 的话,就会共享消息队列,此时可能出现这种情况。
这就导致了很严重的错误,会使得进程崩溃。修正的方式,可以是将消息完全准备好之后,再放入队列,如下:
/*
* 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);
}
}
这样就使得消息的数据被写完了,才被放入队列中,如下:
不过如果考虑线程安全,多个线程对同一个消息队列进行操作时,就要加锁:
/*
* 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
-
分享到:
相关推荐
1. 在OpenRTMFP-Cumulus/CumulusLib目录下运行`make`。 2. 然后转到OpenRTMFP-Cumulus/CumulusServer目录,再次运行`make`。 如果在编译过程中遇到头文件或库文件找不到的问题,你需要检查Makefile,确保路径设置...
在使用Cumulus时,首先需要理解其基本架构和工作流程。这可能包括设置项目、导入数据、配置标签系统等步骤。对于源码爱好者,阅读和理解Cumulus的源码可以深入了解其内部逻辑,学习如何构建类似的工具。对于普通用户...
6. **QEMU虚拟化**:通过使用“cumulus-linux-4.4.0-vx-amd64-qemu.qcow2”镜像,用户可以在本地或者云环境中快速搭建一个Cumulus Linux的仿真环境,进行功能测试、学习或开发验证,而无需物理硬件。 7. **EVE环境*...
**wp-cumulus插件详解** `wp-cumulus`是一款专门为WordPress博客设计的炫酷三维标签云插件。这款插件以其独特的视觉效果和良好的用户体验,在众多的WordPress标签云插件中脱颖而出。通过使用`wp-cumulus`,用户可以...
高性能计算云 目标 ...$ vi /opt/hpccloud/cumulus/cumulus/conf/config.json +- > Fix host to be localhost +- > baseUrl: " http://localhost:8080/api/v1 " , $ sudo service celeryd restar
这本食谱在 vanilla Debian 上创建了一个交换机覆盖,并且还部署在 Cumulus 路由器/交换机上。 要求 测试 访问 Debian Wheezy 盒子 生产 访问 Cumulus HCL [1] 开关(Accton AS6701_32X,这就是这本食谱最初的目的)...
在使用过程中,确保你的网站已经安装了Flash插件,因为"wp-cumulus" 在运行时需要依赖Flash支持。不过,随着HTML5技术的发展,一些现代版本可能提供了HTML5替代方案,以便在不支持Flash的设备上也能正常显示。 总的...
使用Cumulus,开发者可以创建具有音视频流功能的应用程序,例如视频会议、在线教育平台、多人游戏等。Cumulus库不仅实现了OpenRTMFP协议,还提供了一套灵活的API,使得开发者能够方便地控制和管理P2P连接。 在...
《WordPress中的wp-cumulus 3D云标签详解》 在WordPress这个强大的开源博客平台中,wp-cumulus是一款极具特色的3D云标签插件。它以其独特的视觉效果和交互体验,为用户提供了全新的标签展示方式,使得博客的分类和...
【 Cumulus:基于网络编码的分布式文件系统 】 在分布式计算领域,分布式文件系统是支撑大规模数据处理和存储的关键技术之一。Cumulus 是一个创新性的分布式文件系统,它利用网络编码理论来优化系统的容错能力和...
这里给出了cumulus/OpenRTMFP的git官网提到的视频会话样例的AS3代码,包括服务器端和客户端两部分,我已经在<使用Cumulus和Flash Player搭建视频会议示例>http://blog.csdn.net/tao_627/article/details/18041473中给...
Mellanox Cumulus学习,基本使用,培训资源
openrtmfp又名Cumulus Server是一个完全开源和跨平台的可扩展的RTMFP服务器脚本。Cumulus Server在GPL 框架下遵循速度、优势、跨平台、轻量和高质量代码。Cumulus Server的每一个版本都是通过严格测试和审核的。可...
积云Cumulus 是的免费、开源替代品,它利用您自己的 S3 进行存储。下载您可以在下载最新版本更改默认截图目录这是可选的。 默认情况下,OS X 会将屏幕截图放在您的桌面上。 但是,如果您希望他们去其他地方,您可以...
积云框架 :open_book: 文献资料 最新文档。 文档。 更多信息 有关此项目的更多信息,以及有关NASA的地球观测系统数据和信息系统(EOSDIS)及其云工作的更多信息,请联系或访问 。...这是用于Cumulus开
Cumulus集成测试项目[已弃用] ... 运行测试时,默认情况下,测试将使用spec/config.yml定义的配置来尝试执行工作流程。 这些变量是在CircleCI上运行测试所必需的。 可以在您自己的spec/config.override
【描述】"完美支持中文wp-cumulus插件源码(无锯齿无抖动7K大小)"说明这个插件是为中文环境优化的,解决了在显示中文标签时可能出现的锯齿或抖动问题,同时强调了其源代码的轻量化,只有7K大小,意味着它在加载和...
大名鼎鼎的WP-CUMULUS 3D标签云,已经改成支持中文标签,可在.htm自行添加标签链接,可以单机玩耍测试,不需要安装WordPress然后装插件~~ 主要是有些童鞋只是想要3D标签云动画,所以就提取重要文件出来稍作修改下.
Python库是开发者在编程时经常会使用到的重要工具,它们提供了丰富的功能,可以帮助程序员高效地完成各种任务。在本文中,我们将深入探讨名为“cumulus”的Python库,版本为1.1.0,它以tar.gz格式进行压缩。这个库...
Drupal 是一个广泛使用的开源内容管理系统(CMS),它允许用户创建和管理复杂的网站。在这个特定的场景中,我们关注的是 Drupal 的两个模块:Tagadelic 和 Cumulus,它们都是用来实现标签云(Tag Cloud)效果的。 ...