ZeroMQ: I want Publish–Subscribe to drop older messages in favor of newer ones

前端 未结 2 647
无人共我
无人共我 2021-01-19 18:11

I\'m using ZeroMQ publish–subscribe sockets to connect two processes. The publishing process is a sensor, and has a much faster refresh rate than the subscription process. I

相关标签:
2条回答
  • 2021-01-19 18:31

    Okay, I found a solution, but I don't know if it's the best one — so I won't mark it as correct just yet.

    zmq::message_t message;
    int events = 0;
    size_t events_size = sizeof(int);
    
    // Priming read
    subscriber.recv(&message);
    
    // See if there are more messages to read
    subscriber.getsockopt(ZMQ_EVENTS, static_cast<void*>(&events), &events_size);
    while (events & ZMQ_POLLIN) {
    
      // Receive the new (and perhaps most recent) message
      subscriber.recv(&message);
    
      // Poll again for additional messages
      subscriber.getsockopt(ZMQ_EVENTS, static_cast<void*>(&events), &events_size);
    }
    
    // Now, message points to the most recent received data.
    

    This strategy has the added advantage that the queue shouldn't fill up. The disadvantage is that my publisher could conceivably send faster than this loop in the subscriber could be run, and then it'll loop indefinitely.

    That seems unlikely, but I'd like to make it impossible. I'm not quite sure how to accomplish this goal yet.

    0 讨论(0)
  • 2021-01-19 18:39

    read about the conflate feature from documentation on zeromq (it is kind of new), I think it is exactly what you want.

    From the documentation:

    ZMQ_CONFLATE: Keep only last message If set, a socket shall keep only one message in its inbound/outbound queue, this message being the last message received/the last message to be sent. Ignores 'ZMQ_RCVHWM' and 'ZMQ_SNDHWM' options. Does not support multi-part messages, in particular, only one part of it is kept in the socket internal queue.

    0 讨论(0)
提交回复
热议问题