NAME
Net::RabbitMQ::Channel - use rabbitmq, OOP style
SYNOPSIS
use Net::RabbitMQ::Channel;
my $channel = Net::RabbitMQ::Channel->new (1, {
hosts => {
rabbit1 => {user => 'guest', pass => 'guest'},
rabbit2 => {user => 'guest', pass => 'guest'}
}
});
my $exchange = $channel->exchange_declare (
'test.x',
exchange_type => "topic",
);
my $publisher_key = 'test.*';
# consumer part
my $queue = $channel->queue_declare (
'test.q',
exclusive => 0,
);
$queue->bind ($exchange, $publisher_key);
# publisher part
$channel->publish ($publisher_key, $message, {exchange => $exchange->name}, {
app_id => 'test',
timestamp => time
});
# consumer part
my $message = $queue->get;
METHODS
init
- new
-
my $channel = Net::RabbitMQ::Channel->new (1, { # mandatory hosts => {host_name => {user => 'user_name', pass => 'password'}}, # optional });
when creating Net::RabbitMQ::Channel you must provide channel number and configuration options.
in the current version only 'hosts' key is supported. each key for 'hosts' specifies one rabbitmq broker configuration. if current broker connection fails, module tries to reconnect to another one.
working with channel
- exchange_declare
-
declares exchange
my $exchange = $self->exchange_declare ( 'test.exchange', package => 'My::Exchange', # Net::RabbitMQ::Exchange if omitted passive => 0, # 0 durable => 1, # 1 auto_delete => 0, # 0 exchange_type => "topic" );
- queue_declare
-
declares queue
my $queue = $self->queue_declare ( 'test.queue', package => 'My::Queue', # Net::RabbitMQ::Queue if omitted passive => 0, # 0 durable => 1, # 1 auto_delete => 0, # 0 exclusive => 0 );
- publish
-
publish message to routing key
a typical workflow for a producer role is: open channel, declare exchange, and publish message via routing key
please, note: queue for recieving that message must be declared and binded to exchange using routing key prior to message publishing.
$channel->publish ($publisher_key, $message, {exchange => $exchange->name}, { # content_type => $string, # content_encoding => $string, # correlation_id => $string, # reply_to => $string, # expiration => $string, # message_id => $string, # type => $string, # user_id => $string, app_id => 'test', # delivery_mode => $integer, # priority => $integer, timestamp => time });
- close
-
stub
AUTHOR
Ivan Baktsheev, <apla at the-singlers.us>
BUGS
Please report any bugs or feature requests to my email address, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Net::RabbitMQ::Channel. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.
SUPPORT
ACKNOWLEDGEMENTS
COPYRIGHT & LICENSE
Copyright 2010-2011 Ivan Baktsheev
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself.