NAME

Number::YAUID - A decentralized unique ID generator (int64)

SYNOPSIS

use Number::YAUID;

my $object = Number::YAUID->new("/tmp/lock.file", "/etc/node.id");
# OR
#my $object = Number::YAUID->new("/tmp/lock.file", undef, node_id => 321);
die get_error_text_by_code($object) unless ref $object;

print "Max inc on sec: ", get_max_inc(), "\n";
print "Max node id: ", get_max_node_id(), "\n";
print "Max timestamp: ", get_max_timestamp(), "\n";

foreach (0..5000)
{
	my $key = $object->get_key();
	die get_error_text_by_code($object->get_error_code()) if $object->get_error_code();
	
	print "key: ", $key, "\n";
	print "\ttimestamp: ", timestamp_to_datetime( $object->get_timestamp_by_key($key) ), "\n";
 	print "\tnode id: "  , $object->get_node_id_by_key($key)  , "\n";
	print "\tinc id: "   , $object->get_inc_id_by_key($key)   , "\n";
}

DESCRIPTION

Id generation at a node should not require coordination with other nodes. Ids should be roughly time-ordered when sorted lexicographically.

METHODS

new

my $object = Number::YAUID->new(<file path to lockfile>, <file path to node id>[, params args]);

my %p_args = (
	try_count  => 0,     # count of key get attempts, 0 = unlimited
	sleep_usec => 35000, # sleep 0.35 sec if limit key inc expired on current second
	node_id    => 321    # current node id
);

my $object = Number::YAUID->new("/tmp/lock.file", undef, %p_args);

Create and prepare base structure. Return object or undef if something went wrong.

get_key

my $key = $object->get_key();

Return a unique ID

get_period_key_by_datetime

my $key = get_period_key_by_datetime(<from datetime>, <to datetime>, <from node ID>, <to node ID>);
from datetime

YYYY-MM-DD hh:mm:ss

to datetime

YYYY-MM-DD hh:mm:ss if <to datetime> = 0, then <to datetime> = <from datetime>

from node ID

1 to get_max_node_id() if <from node ID> = 0, then <from node ID> = 1

to node ID

1 to get_max_node_id() if <to node ID> = 0, then <to node ID> = get_max_node_id()

Return arrey ref where [0] = min, [1] = max unique ID

get_period_key_by_timestamp

my $key = get_period_key_by_timestamp(<from timestamp>, <to timestamp>, <from node ID>, <to node ID>);
from timestamp

timestamp

to timestamp

timestamp if <to timestamp> = 0, then <to timestamp> = <from timestamp>

from node ID

1 to get_max_node_id() if <from node ID> = 0, then <from node ID> = 1

to node ID

1 to get_max_node_id() if <to node ID> = 0, then <to node ID> = get_max_node_id()

Return arrey ref where [0] = min, [1] = max unique ID

get_error_code

$object->get_error_code();

Return error code.

get_error_text_by_code

get_error_text_by_code(<error code>);

Return description by error code

get_timestamp_by_key

$object->get_timestamp_by_key(<key>);

Return timestamp from a key

get_node_id_by_key

$object->get_node_id_by_key(<key>);

Return node id from a key

get_inc_id_by_key

$object->get_inc_id_by_key(<key>);

Return inc id from a key

timestamp_to_datetime

timestamp_to_datetime(<timestamp>);

Convert timestamp to datetime (YYYY-MM-DD hh:mm:ss)

DESTROY

undef $obj;

Free mem and destroy object.

AUTHOR

Alexander Borisov <lex.borisov@gmail.com>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Alexander Borisov.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.