Why not adopt me?
This distribution is up for adoption!
If you're interested then please contact the PAUSE module admins via
email.
NAME
POEx::ZMQ3::Publisher - A PUB-type ZeroMQ socket
SYNOPSIS
use POE;
my $zpub = POEx::ZMQ3::Publisher->new();
POE::Session->create(
inline_states => {
_start => sub {
## Bind our Publisher to some endpoints:
$zpub->start(
'tcp://127.0.0.1:5665',
'tcp://127.0.0.1:1234',
);
## Our session wants all emitted events:
$_[KERNEL]->post( $zpub->session_id,
'subscribe',
'all'
);
## Push messages on a timer loop forever:
$_[KERNEL]->delay( push_messages => 1 );
},
zeromq_publishing_on => sub {
my $endpoint = $_[ARG0];
print "Publishing on $endpoint\n";
},
push_messages => sub {
$zpub->publish(
'This is data \o/'
);
$_[KERNEL]->delay( push_messages => 1 );
},
}
);
$poe_kernel->run;
DESCRIPTION
A lightweight ZeroMQ publisher-type socket using POEx::ZMQ3::Role::Emitter.
Methods
start
$zpub->start( @publish_on );
Start the Publisher and bind some endpoint(s).
stop
$zpub->stop;
Stop the Publisher, closing out the socket and stopping the event emitter.
publish
$zpub->publish( @data );
Publish some item(s) to the ZeroMQ socket as individual single-part messages.
This base class does no special serialization on its own.
publish_multipart
$zpub->publish_multipart( @data );
Publish multi-part data. For PUB-type sockets, this is frequently used to create message envelopes a SUB-type socket can subscribe to:
$zpub->publish_multipart( $prefix, $data );
Events
zeromq_publishing_on
Emitted when we are initialized; $_[ARG0] is the endpoint we are publishing on.
SEE ALSO
AUTHOR
Jon Portnoy <avenj@cobaltirc.org>