# NAME
Cache::KyotoTycoon - KyotoTycoon client library
# SYNOPSIS
use Cache::KyotoTycoon;
my $kt = Cache::KyotoTycoon->new(host => '127.0.0.1', port => 1978);
$kt->set('foo' => bar');
$kt->get('foo'); # => 'bar'
# DESCRIPTION
KyotoTycoon.pm is [KyotoTycoon](
http://fallabs.com/kyototycoon/) client library for Perl5.
__THIS MODULE IS IN ITS BETA QUALITY. THE API MAY CHANGE IN THE FUTURE__.
# ERROR HANDLING POLICY
This module throws exception if got __Server Error__.
# CONSTRUCTOR OPTIONS
- `timeout`
Timeout value for each request in seconds.
_Default_: 1 second
- `host`
Host name of server machine.
_Default_: '127.0.0.1'
- `port`
Port number of server process.
_Default_: 1978
- `db`
DB name or id.
_Default_: 0
# METHODS
- `$kt->db()`
Getter/Setter of DB name/id.
- `my $cursor: Cache::KyotoTycoon::Cursor = $kt->make_cursor($cursor_number: Int);`
Create new cursor object. This method returns instance of [Cache::KyotoTycoon::Cursor](
http://search.cpan.org/perldoc?Cache::KyotoTycoon::Cursor).
- `my $res = $kt->echo($args)`
The server returns $args. This method is useful for testing server.
$args is hashref.
_Return_: the copy of $args.
- `$kt->report()`
Get server report.
_Return_: server status information in hashref.
- `my $output = $kt->play_script($name[, \%input]);`
Call a procedure of the script language extension.
_$name_: the name of the procedure to call.
_\\%input_: (optional): arbitrary records.
_Return_: response of the script in hashref.
- `my $info = $kt->status()`
Get database status information.
_Return_: database status information in hashref.
- `$kt->clear()`
Remove all elements for the storage.
_Return_: Not a useful value.
- `$kt->synchronize($hard:Bool, $command);`
Synchronize database with file system.
_$hard_: call fsync() or not.
_$command_: call $command in synchronization state.
_Return_: 1 if succeeded, 0 if $command returns false.
- `$kt->set($key, $value, $xt);`
Store _$value_ to _$key_.
_$xt_: expiration time. If $xt>0, expiration time in seconds from now. If $xt<0, the epoch time. It is never remove if missing $xt.
_Return_: not a useful value.
- `my $ret = $kt->add($key, $value, $xt);`
Store record. This method is not store if the _$key_ is already in the database.
_$xt_: expiration time. If $xt>0, expiration time in seconds from now. If $xt<0, the epoch time. It is never remove if missing $xt.
_Return_: 1 if succeeded. 0 if $key is already in the db.
- `my $ret = $kt->replace($key, $value, $xt);`
Store the record, ignore if the record is not exists in the database.
_$xt_: expiration time. If $xt>0, expiration time in seconds from now. If $xt<0, the epoch time. It is never remove if missing $xt.
_Return_: 1 if succeeded. 0 if $key is not exists in the database.
- `my $ret = $kt->append($key, $value, $xt);`
Store the record, append the $value to existent record if already exists entry.
_$xt_: expiration time. If $xt>0, expiration time in seconds from now. If $xt<0, the epoch time. It is never remove if missing $xt.
_Return_: not useful value.
- `my $ret = $kt->increment($key, $num, $xt);`
_$num_: incremental
_Return_: value after increment.
- `my $ret = $kt->increment_double($key, $num, $xt);`
_$num_: incremental
_Return_: value after increment.
- `my $ret = $kt->cas($key, $oval, $nval, $xt);`
compare and swap.
_$oval_: old value
_$nval_: new value
_Return_: 1 if succeeded, 0 if failed.
- `$kt->remove($key);`
Remove _$key_ from database.
_Return_ 1 if removed, 0 if record does not exists.
- `my $val = $kt->get($key);`
Get _$key_ from database.
_Return_: the value from database in scalar context. ($value, $xt) in list context. _undef_ or empty list if not exists in database.
- `$kt->set_bulk(\%values);`
Store multiple values in one time.
_Return_: not useful value.
- `$kt->remove_bulk(\@keys);`
Remove multiple keys in one time.
_Return_: not useful value.
- `my $hashref = $kt->get_bulk(\@keys);`
Get multiple values in one time.
_Return_: records in hashref.
- `$kt->vacuum([$step]);`
Scan the database and eliminate regions of expired records.
_input_: step: (optional): the number of steps. If it is omitted or not more than 0, the whole region is scanned.
_Return_: not useful.
- `my $hashref = $kt->match_prefix($prefix, $max);`
Get list of matching keys.
_Return_: records in hashref.
- `my $hashref = $kt->match_regex($regex, $max);`
Get list of matching keys.
_Return_: records in hashref.
- `my $hashref = $kt->match_similar($origin, $range, $utf8, $max);`
Get list of matching keys.
_Return_: records in hashref.
# AUTHOR
Tokuhiro Matsuno <tokuhirom AAJKLFJEF@ GMAIL COM>
# SEE ALSO
- `[KyotoTycoon](
http://fallabs.com/kyototycoon/)`
- `
http://fallabs.com/mikio/tech/promenade.cgi?id=99`
# LICENSE
Copyright (C) Tokuhiro Matsuno
This library is free software; you can redistribute it and/or modify
it under the same terms as Perl itself.