zeromq 多线程 publish,导致程序崩溃,请教大神。。。。。。。。。。。。

2018-04-28 16:01:50 +08:00
 duanhui8
zeromq 使用订阅发布模式,多线程同时 zmq_sendmsg(g_publisher,&reply, ZMQ_DONTWAIT),程序直接崩了

堆栈信息:
Program received signal SIGABRT, Aborted.
[Switching to Thread 0x7f0dfcff9700 (LWP 63108)]
0x00007f0eb4a421f7 in raise () from /lib64/libc.so.6
(gdb) bt
#0 0x00007f0eb4a421f7 in raise () from /lib64/libc.so.6
#1 0x00007f0eb4a438e8 in abort () from /lib64/libc.so.6
#2 0x00007f0e4c1a2789 in zmq::zmq_abort (errmsg_=errmsg_@entry=0x7f0e4c1d5c6d "check ()") at src/err.cpp:83
#3 0x00007f0e4c1a9252 in zmq::msg_t::size (this=0x7f0dd0000900) at src/msg.cpp:254
#4 0x00007f0e4c1ce562 in zmq::v2_encoder_t::message_ready (this=0x7f0dd0009480) at src/v2_encoder.cpp:53
#5 0x00007f0e4c1c3951 in zmq::stream_engine_t::out_event (this=0x7f0dd00008e0) at src/stream_engine.cpp:363
#6 0x00007f0e4c1b934e in zmq::session_base_t::read_activated (this=0x7f0dd0000d80, pipe_=0x7f0dd00092a0)
at src/session_base.cpp:264

难道 zero 不知道多线程 publish 消息吗?有小伙伴碰到这种问题没?
性能要求高,不能加同步锁,有其他办法解决吗?
3680 次点击
所在节点    程序员
5 条回复
duanhui8
2018-04-28 16:37:01 +08:00
有办法解决吗?
zn
2018-04-28 16:53:36 +08:00
考虑每个线程自己维护一个 publisher ?
duanhui8
2018-04-28 16:55:45 +08:00
@zn 有线程池,线程数会动态变化,数量不固定
duanhui8
2018-04-28 16:56:22 +08:00
头大,整合到自己程序,才发现线程不安全
exch4nge
2018-04-28 17:22:55 +08:00
对 zmq 不熟,强行搜了下。http://api.zeromq.org/2-1:zmq#toc4 按上面所说一个 socket 是线程不安全的。
估计得按 @zn 所说一个线程一个 socket,线程池线程起来的时候建立连接什么的。。。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/450703

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX