Bot-Cobalt
view release on metacpan or search on metacpan
lib/Bot/Cobalt/DB.pm view on Meta::CPAN
## Defaults to 5s:
timeout => 10,
## Normally, references are serialized transparently.
## If raw is enabled, no serialization filter is used and you're
## on your own.
raw => 0,
);
=head2 Opening and closing
Database operations should be contained within a dbopen/dbclose:
## open, put, close:
$db->dbopen || croak "dbopen failure";
$db->put($key, $data);
$db->dbclose;
## open for read-only, read, close:
$db->dbopen(ro => 1) || croak "dbopen failure";
my $data = $db->get($key);
$db->dbclose;
Methods will fail if the DB is not open.
If the DB for this object is open when the object is DESTROY'd, Bot::Cobalt::DB
will attempt to close it safely.
=head2 Locking
Proper locking is done -- that means the DB is 're-tied' after a lock is
granted and state cannot change between database open and lock time.
The attempt to gain a lock will time out after five seconds (and
L</dbopen> will return boolean false).
The lock is cleared on L</dbclose>.
If the Bot::Cobalt::DB object is destroyed, it will attempt to dbclose
for you, but it is good practice to keep track of your open/close
calls and attempt to close as quickly as possible.
=head2 Methods
=head3 dbopen
B<dbopen> opens and locks the database. If 'ro => 1' is specified,
this is a LOCK_SH shared (read) lock; otherwise it is a LOCK_EX
exclusive (write) lock.
Try to call a B<dbclose> as quickly as possible to reduce locking
contention.
dbopen() will return false (and possibly warn) if the database could
not be opened (probably due to lock timeout).
=head3 is_open
Returns a boolean value representing whether or not the DB is currently
open and locked.
=head3 dbclose
B<dbclose> closes and unlocks the database.
=head3 put
The B<put> method adds an entry to the database:
$db->put($key, $value);
The value can be any data structure serializable by L<JSON::MaybeXS>.
Note that keys should be properly encoded:
my $key = "\x{263A}";
utf8::encode($key);
$db->put($key, $data);
=head3 get
The B<get> method retrieves a (deserialized) key.
$db->put($key, { Some => 'hash' } );
## . . . later on . . .
my $ref = $db->get($key);
=head3 del
The B<del> method removes a key from the database.
$db->del($key);
=head3 dbkeys
B<dbkeys> will return a list of keys in list context, or the number
of keys in the database in scalar context.
=head3 dbdump
You can serialize/export the entirety of the DB via B<dbdump>.
## Export to a HASH
my $dbcopy = $db->dbdump('HASH');
## YAML::Syck
my $yamlified = $db->dbdump('YAML');
## YAML::XS
my $yamlified = $db->dbdump('YAMLXS');
## JSON::MaybeXS
my $jsonified = $db->dbdump('JSON');
See L<Bot::Cobalt::Serializer> for more on C<freeze()> and valid formats.
A tool called B<cobalt2-dbdump> is available as a
simple frontend to this functionality. See C<cobalt2-dbdump --help>
=head1 FORMAT
B<Bot::Cobalt::DB> databases are Berkeley DB 1.x, with NULL-terminated records
and values stored as JSON. They're intended to be easily portable to
( run in 0.384 second using v1.01-cache-2.11-cpan-39bf76dae61 )