NAME

RedisDB::Cluster - client for redis cluster

SYNOPSIS

my $cluster = RedisDB::Cluster->new( startup_nodes => \@nodes );
$cluster->set( 'foo', 'bar' );
my $res = $cluster->get('foo');

DESCRIPTION

This module allows you to access redis cluster.

METHODS

$self->new(startup_nodes => \@nodes)

create a new connection to cluster. Startup nodes should contain array of hashes that contains addresses of some nodes in the cluster. Each hash should contain 'host' and 'port' elements. Constructor will try to connect to nodes from the list and from the first node to which it will be able to connect it will retrieve information about all cluster nodes and slots mappings.

$self->execute($command, @args)

sends command to redis and returns the reply. It determines the cluster node to send command to from the first key in @args, sending commands that does not include key as an argument is not supported. If @args contains several keys, all of them should belong to the same slot, otherwise redis-server will return an error if some of the keys are stored on a different node.

Module also defines wrapper methods with names matching corresponding redis commands, so you can use

$cluster->set( "foo", "bar" );
$cluster->inc("baz");

instead of

$cluster->execute( "set", "foo", "bar" );
$cluster->execute( "inc", "baz" );

$self->random_connection

return RedisDB object that is connected to some node of the cluster. Note, that in most cases this method will return the same connection every time.

CLUSTER MANAGEMENT METHODS

The following methods can be used for cluster management -- to add or remove a node, or migrate slot from one node to another.

$self->add_new_node($address[, $master_id])

attach node with the specified $address to the cluster. If $master_id is specified, the new node is configured as a replica of the master with the specified ID, otherwise it will be a master node itself. Address should be specified as a hash containing host and port elements.

$self->migrate_slot($slod, $destination_node)

migrates specified slot to the given $destination_node from the current node responsible for this slot. Destinations node should be specified as a hash containing host and port elements. For details check "Cluster live reconfiguration" section in the Redis Cluster Specification.

$self->remove_node($node)

removes node from the cluster. If the node is a slave, it simply shuts the node down and sends CLUSTER FORGET command to all other cluster nodes. If the node is a master node, the method first migrates all slots from it to other nodes.

SERVICE FUNCTIONS

crc16($buf)

compute crc16 for the specified buffer as defined in redis cluster specification

key_slot($key)

return slot number for the given $key

AUTHOR

Pavel Shaydo, <zwon at cpan.org>

LICENSE AND COPYRIGHT

Copyright 2011-2016 Pavel Shaydo.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.