V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
duanhui8
V2EX  ›  程序员

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

  •  
  •   duanhui8 · 2018-04-28 16:01:50 +08:00 · 3669 次点击
    这是一个创建于 2426 天前的主题,其中的信息可能已经有所发展或是发生改变。
    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 消息吗?有小伙伴碰到这种问题没?
    性能要求高,不能加同步锁,有其他办法解决吗?
    5 条回复    2018-04-28 17:22:55 +08:00
    duanhui8
        1
    duanhui8  
    OP
       2018-04-28 16:37:01 +08:00
    有办法解决吗?
    zn
        2
    zn  
       2018-04-28 16:53:36 +08:00
    考虑每个线程自己维护一个 publisher ?
    duanhui8
        3
    duanhui8  
    OP
       2018-04-28 16:55:45 +08:00
    @zn 有线程池,线程数会动态变化,数量不固定
    duanhui8
        4
    duanhui8  
    OP
       2018-04-28 16:56:22 +08:00
    头大,整合到自己程序,才发现线程不安全
    exch4nge
        5
    exch4nge  
       2018-04-28 17:22:55 +08:00
    对 zmq 不熟,强行搜了下。http://api.zeromq.org/2-1:zmq#toc4 按上面所说一个 socket 是线程不安全的。
    估计得按 @zn 所说一个线程一个 socket,线程池线程起来的时候建立连接什么的。。。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2708 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 15:11 · PVG 23:11 · LAX 07:11 · JFK 10:11
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.