| | man : BDB(3p)
BDB(3) User Contributed Perl Documentation BDB(3)
NAME
BDB - Asynchronous Berkeley DB access
SYNOPSIS
use BDB;
my $env = db_env_create;
mkdir "bdtest", 0700;
db_env_open
$env,
"bdtest",
BDB::INIT_LOCK | BDB::INIT_LOG | BDB::INIT_MPOOL
| BDB::INIT_TXN | BDB::RECOVER | BDB::USE_ENVIRON | BDB::CREATE,
0600;
$env->set_flags (BDB::AUTO_COMMIT | BDB::TXN_NOSYNC, 1);
my $db = db_create $env;
db_open $db, undef, "table", undef, BDB::BTREE, BDB::AUTO_COMMIT | BDB::CREATE
| BDB::READ_UNCOMMITTED, 0600;
db_put $db, undef, "key", "data", 0, sub {
db_del $db, undef, "key";
};
db_sync $db;
# when you also use Coro, management is easy:
use Coro::BDB;
# automatic event loop integration with AnyEvent:
use AnyEvent::BDB;
# automatic result processing with EV:
my $WATCHER = EV::io BDB::poll_fileno, EV::READ, \&BDB::poll_cb;
# with Glib:
add_watch Glib::IO BDB::poll_fileno,
in => sub { BDB::poll_cb; 1 };
# or simply flush manually
BDB::flush;
DESCRIPTION
See the BerkeleyDB documentation
(<http://www.oracle.com/technology/documentation/berkeley-db/db/index.html>).
The BDB API is very similar to the C API (the translation
has been very faithful).
See also the example sections in the document below and
possibly the eg/ subdirectory of the BDB distribution.
Last not least see the IO::AIO documentation, as that
module uses almost the same asynchronous request model as
this module.
perl v5.10.0 2009-07-17 1
BDB(3) User Contributed Perl Documentation BDB(3)
I know this is woefully inadequate documentation. Send a
patch!
REQUEST ANATOMY AND LIFETIME
Every request method creates a request. which is a C data
structure not directly visible to Perl.
During their existance, bdb requests travel through the
following states, in order:
ready
Immediately after a request is created it is put into
the ready state, waiting for a thread to execute it.
execute
A thread has accepted the request for processing and
is currently executing it (e.g. blocking in read).
pending
The request has been executed and is waiting for
result processing.
While request submission and execution is fully
asynchronous, result processing is not and relies on
the perl interpreter calling "poll_cb" (or another
function with the same effect).
result
The request results are processed synchronously by
"poll_cb".
The "poll_cb" function will process all outstanding
aio requests by calling their callbacks, freeing
memory associated with them and managing any groups
they are contained in.
done
Request has reached the end of its lifetime and holds
no resources anymore (except possibly for the Perl
object, but its connection to the actual aio request
is severed and calling its methods will either do
nothing or result in a runtime error).
BERKELEYDB FUNCTIONS
All of these are functions. The create functions simply
return a new object and never block. All the remaining
functions take an optional callback as last argument. If
it is missing, then the function will be executed
synchronously. In both cases, $! will reflect the return
value of the function.
BDB functions that cannot block (mostly functions that
manipulate settings) are method calls on the relevant
objects, so the rule of thumb is: if it's a method, it's
perl v5.10.0 2009-07-17 2
BDB(3) User Contributed Perl Documentation BDB(3)
not blocking, if it's a function, it takes a callback as
last argument.
In the following, $int signifies an integer return value,
"bdb_filename" is a "filename" (octets on unix, madness on
windows), "U32" is an unsigned 32 bit integer, "int" is
some integer, "NV" is a floating point value.
Most "SV *" types are generic perl scalars (for input and
output of data values).
The various "DB_ENV" etc. arguments are handles return by
"db_env_create", "db_create", "txn_begin" and so on. If
they have an appended "_ornull" this means they are
optional and you can pass "undef" for them, resulting a
NULL pointer on the C level.
The "SV *callback" is the optional callback function to
call when the request is completed. This last callback
argument is special: the callback is simply the last
argument passed. If there are "optional" arguments before
the callback they can be left out. The callback itself can
be left out or specified as "undef", in which case the
function will be executed synchronously.
For example, "db_env_txn_checkpoint" usually is called
with all integer arguments zero. These can be left out, so
all of these specify a call to "DB_ENV->txn_checkpoint",
to be executed asynchronously with a callback to be
called:
db_env_txn_checkpoint $db_env, 0, 0, 0, sub { };
db_env_txn_checkpoint $db_env, 0, 0, sub { };
db_env_txn_checkpoint $db_env, sub { };
While these all specify a call to "DB_ENV->txn_checkpoint"
to be executed synchronously:
db_env_txn_checkpoint $db_env, 0, 0, 0, undef;
db_env_txn_checkpoint $db_env, 0, 0, 0;
db_env_txn_checkpoint $db_env, 0;
BDB functions
Functions in the BDB namespace, exported by default:
$env = db_env_create (U32 env_flags = 0)
flags: RPCCLIENT
db_env_open (DB_ENV *env, bdb_filename db_home, U32 open_flags, int mode, SV *callback = 0)
open_flags: INIT_CDB INIT_LOCK INIT_LOG INIT_MPOOL INIT_REP INIT_TXN RECOVER RECOVER_FATAL USE_ENVIRON USE_ENVIRON_ROOT CREATE LOCKDOWN PRIVATE REGISTER SYSTEM_MEM
db_env_close (DB_ENV *env, U32 flags = 0, SV *callback = 0)
db_env_txn_checkpoint (DB_ENV *env, U32 kbyte = 0, U32 min = 0, U32 flags = 0, SV *callback = 0)
flags: FORCE
perl v5.10.0 2009-07-17 3
BDB(3) User Contributed Perl Documentation BDB(3)
db_env_lock_detect (DB_ENV *env, U32 flags = 0, U32 atype = DB_LOCK_DEFAULT, SV *dummy = 0, SV *callback = 0)
atype: LOCK_DEFAULT LOCK_EXPIRE LOCK_MAXLOCKS LOCK_MAXWRITE LOCK_MINLOCKS LOCK_MINWRITE LOCK_OLDEST LOCK_RANDOM LOCK_YOUNGEST
db_env_memp_sync (DB_ENV *env, SV *dummy = 0, SV *callback = 0)
db_env_memp_trickle (DB_ENV *env, int percent, SV *dummy = 0, SV *callback = 0)
db_env_dbremove (DB_ENV *env, DB_TXN_ornull *txnid, bdb_filename file, bdb_filename database, U32 flags = 0, SV *callback = 0)
db_env_dbrename (DB_ENV *env, DB_TXN_ornull *txnid, bdb_filename file, bdb_filename database, bdb_filename newname, U32 flags = 0, SV *callback = 0)
db_env_log_archive (DB_ENV *env, SV *listp, U32 flags = 0, SV *callback = 0)
$db = db_create (DB_ENV *env = 0, U32 flags = 0)
flags: XA_CREATE
db_open (DB *db, DB_TXN_ornull *txnid, bdb_filename file, bdb_filename database, int type, U32 flags, int mode, SV *callback = 0)
flags: AUTO_COMMIT CREATE EXCL MULTIVERSION NOMMAP RDONLY READ_UNCOMMITTED THREAD TRUNCATE
db_close (DB *db, U32 flags = 0, SV *callback = 0)
flags: DB_NOSYNC
db_verify (DB *db, bdb_filename file, bdb_filename database = 0, SV *dummy = 0, U32 flags = 0, SV *callback = 0)
db_upgrade (DB *db, bdb_filename file, U32 flags = 0, SV *callback = 0)
db_compact (DB *db, DB_TXN_ornull *txn = 0, SV *start = 0, SV *stop = 0, SV *unused1 = 0, U32 flags = DB_FREE_SPACE, SV *unused2 = 0, SV *callback = 0)
flags: FREELIST_ONLY FREE_SPACE
db_sync (DB *db, U32 flags = 0, SV *callback = 0)
db_key_range (DB *db, DB_TXN_ornull *txn, SV *key, SV *key_range, U32 flags = 0, SV *callback = 0)
db_put (DB *db, DB_TXN_ornull *txn, SV *key, SV *data, U32 flags = 0, SV *callback = 0)
flags: APPEND NODUPDATA NOOVERWRITE
db_exists (DB *db, DB_TXN_ornull *txn, SV *key, U32 flags = 0, SV *callback = 0) (v4.6)
db_get (DB *db, DB_TXN_ornull *txn, SV *key, SV *data, U32 flags = 0, SV *callback = 0)
flags: CONSUME CONSUME_WAIT GET_BOTH SET_RECNO MULTIPLE READ_COMMITTED READ_UNCOMMITTED RMW
db_pget (DB *db, DB_TXN_ornull *txn, SV *key, SV *pkey, SV *data, U32 flags = 0, SV *callback = 0)
flags: CONSUME CONSUME_WAIT GET_BOTH SET_RECNO MULTIPLE READ_COMMITTED READ_UNCOMMITTED RMW
db_del (DB *db, DB_TXN_ornull *txn, SV *key, U32 flags = 0, SV *callback = 0)
db_txn_commit (DB_TXN *txn, U32 flags = 0, SV *callback = 0)
flags: TXN_NOSYNC TXN_SYNC
db_txn_abort (DB_TXN *txn, SV *callback = 0)
db_c_close (DBC *dbc, SV *callback = 0)
db_c_count (DBC *dbc, SV *count, U32 flags = 0, SV *callback = 0)
db_c_put (DBC *dbc, SV *key, SV *data, U32 flags = 0, SV *callback = 0)
flags: AFTER BEFORE CURRENT KEYFIRST KEYLAST NODUPDATA
db_c_get (DBC *dbc, SV *key, SV *data, U32 flags = 0, SV *callback = 0)
flags: CURRENT FIRST GET_BOTH GET_BOTH_RANGE GET_RECNO JOIN_ITEM LAST NEXT NEXT_DUP NEXT_NODUP PREV PREV_DUP PREV_NODUP SET SET_RANGE SET_RECNO READ_UNCOMMITTED MULTIPLE MULTIPLE_KEY RMW
db_c_pget (DBC *dbc, SV *key, SV *pkey, SV *data, U32 flags = 0, SV *callback = 0)
db_c_del (DBC *dbc, U32 flags = 0, SV *callback = 0)
db_sequence_open (DB_SEQUENCE *seq, DB_TXN_ornull *txnid, SV *key, U32 flags = 0, SV *callback = 0)
flags: CREATE EXCL
db_sequence_close (DB_SEQUENCE *seq, U32 flags = 0, SV *callback = 0)
db_sequence_get (DB_SEQUENCE *seq, DB_TXN_ornull *txnid, int delta, SV *seq_value, U32 flags = DB_TXN_NOSYNC, SV *callback = 0)
flags: TXN_NOSYNC
db_sequence_remove (DB_SEQUENCE *seq, DB_TXN_ornull *txnid = 0, U32 flags = 0, SV *callback = 0)
flags: TXN_NOSYNC
db_txn_finish (DB_TXN *txn, U32 flags = 0, SV *callback =
0)
This is not actually a Berkeley DB function but a BDB
perl v5.10.0 2009-07-17 4
BDB(3) User Contributed Perl Documentation BDB(3)
module extension. The background for this exytension is:
It is very annoying to have to check every single BDB
function for error returns and provide a codepath out of
your transaction. While the BDB module still makes this
possible, it contains the following extensions:
When a transaction-protected function returns any
operating system error (errno > 0), BDB will set the
"TXN_DEADLOCK" flag on the transaction. This flag is also
set by Berkeley DB functions themselves when an operation
fails with LOCK_DEADLOCK, and it causes all further
operations on that transaction (including "db_txn_commit")
to fail.
The "db_txn_finish" request will look at this flag, and,
if it is set, will automatically call "db_txn_abort"
(setting errno to "LOCK_DEADLOCK" if it isn't set to
something else yet). If it isn't set, it will call
"db_txn_commit" and return the error normally.
How to use this? Easy: just write your transaction
normally:
my $txn = $db_env->txn_begin;
db_get $db, $txn, "key", my $data;
db_put $db, $txn, "key", $data + 1 unless $! == BDB::NOTFOUND;
db_txn_finish $txn;
die "transaction failed" if $!;
That is, handle only the expected errors. If something
unexpected happens (EIO, LOCK_NOTGRANTED or a deadlock in
either db_get or db_put), then the remaining requests
(db_put in this case) will simply be skipped (they will
fail with LOCK_DEADLOCK) and the transaction will be
aborted.
You can use the "$txn->failed" method to check wether a
transaction has failed in this way and abort further
processing (excluding "db_txn_finish").
DB_ENV/database environment methods
Methods available on DB_ENV/$env handles:
DESTROY (DB_ENV_ornull *env)
CODE:
if (env)
env->close (env, 0);
$int = $env->set_data_dir (const char *dir)
$int = $env->set_tmp_dir (const char *dir)
$int = $env->set_lg_dir (const char *dir)
$int = $env->set_shm_key (long shm_key)
$int = $env->set_cachesize (U32 gbytes, U32 bytes, int ncache = 0)
perl v5.10.0 2009-07-17 5
BDB(3) User Contributed Perl Documentation BDB(3)
$int = $env->set_flags (U32 flags, int onoff = 1)
$int = $env->log_set_config (U32 flags, int onoff = 1) (v4.7)
$int = $env->set_intermediate_dir_mode (const char *modestring) (v4.7)
$env->set_errfile (FILE *errfile = 0)
$env->set_msgfile (FILE *msgfile = 0)
$int = $env->set_verbose (U32 which, int onoff = 1)
$int = $env->set_encrypt (const char *password, U32 flags = 0)
$int = $env->set_timeout (NV timeout_seconds, U32 flags = SET_TXN_TIMEOUT)
$int = $env->set_mp_max_openfd (int maxopenfd);
$int = $env->set_mp_max_write (int maxwrite, int maxwrite_sleep);
$int = $env->set_mp_mmapsize (int mmapsize_mb)
$int = $env->set_lk_detect (U32 detect = DB_LOCK_DEFAULT)
$int = $env->set_lk_max_lockers (U32 max)
$int = $env->set_lk_max_locks (U32 max)
$int = $env->set_lk_max_objects (U32 max)
$int = $env->set_lg_bsize (U32 max)
$int = $env->set_lg_max (U32 max)
$int = $env->mutex_set_increment (U32 increment)
$int = $env->mutex_set_tas_spins (U32 tas_spins)
$int = $env->mutex_set_max (U32 max)
$int = $env->mutex_set_align (U32 align)
$txn = $env->txn_begin (DB_TXN_ornull *parent = 0, U32 flags = 0)
flags: READ_COMMITTED READ_UNCOMMITTED TXN_NOSYNC TXN_NOWAIT TXN_SNAPSHOT TXN_SYNC TXN_WAIT TXN_WRITE_NOSYNC
$txn = $env->cdsgroup_begin; (v4.5)
Example:
use AnyEvent;
use BDB;
our $FH; open $FH, "<&=" . BDB::poll_fileno;
our $WATCHER = AnyEvent->io (fh => $FH, poll => 'r', cb => \&BDB::poll_cb);
BDB::min_parallel 8;
my $env = db_env_create;
mkdir "bdtest", 0700;
db_env_open
$env,
"bdtest",
BDB::INIT_LOCK | BDB::INIT_LOG | BDB::INIT_MPOOL | BDB::INIT_TXN | BDB::RECOVER | BDB::USE_ENVIRON | BDB::CREATE,
0600;
$env->set_flags (BDB::AUTO_COMMIT | BDB::TXN_NOSYNC, 1);
DB/database methods
Methods available on DB/$db handles:
perl v5.10.0 2009-07-17 6
BDB(3) User Contributed Perl Documentation BDB(3)
DESTROY (DB_ornull *db)
CODE:
if (db)
{
SV *env = (SV *)db->app_private;
db->close (db, 0);
SvREFCNT_dec (env);
}
$int = $db->set_cachesize (U32 gbytes, U32 bytes, int ncache = 0)
$int = $db->set_flags (U32 flags)
flags: CHKSUM ENCRYPT TXN_NOT_DURABLE
Btree: DUP DUPSORT RECNUM REVSPLITOFF
Hash: DUP DUPSORT
Queue: INORDER
Recno: RENUMBER SNAPSHOT
$int = $db->set_encrypt (const char *password, U32 flags)
$int = $db->set_lorder (int lorder)
$int = $db->set_bt_minkey (U32 minkey)
$int = $db->set_re_delim (int delim)
$int = $db->set_re_pad (int re_pad)
$int = $db->set_re_source (char *source)
$int = $db->set_re_len (U32 re_len)
$int = $db->set_h_ffactor (U32 h_ffactor)
$int = $db->set_h_nelem (U32 h_nelem)
$int = $db->set_q_extentsize (U32 extentsize)
$dbc = $db->cursor (DB_TXN_ornull *txn = 0, U32 flags = 0)
flags: READ_COMMITTED READ_UNCOMMITTED WRITECURSOR TXN_SNAPSHOT
$seq = $db->sequence (U32 flags = 0)
Example:
my $db = db_create $env;
db_open $db, undef, "table", undef, BDB::BTREE, BDB::AUTO_COMMIT | BDB::CREATE | BDB::READ_UNCOMMITTED, 0600;
for (1..1000) {
db_put $db, undef, "key $_", "data $_";
db_key_range $db, undef, "key $_", my $keyrange;
my ($lt, $eq, $gt) = @$keyrange;
}
db_del $db, undef, "key $_" for 1..1000;
db_sync $db;
DB_TXN/transaction methods
Methods available on DB_TXN/$txn handles:
perl v5.10.0 2009-07-17 7
BDB(3) User Contributed Perl Documentation BDB(3)
DESTROY (DB_TXN_ornull *txn)
CODE:
if (txn)
txn->abort (txn);
$int = $txn->set_timeout (NV timeout_seconds, U32 flags = SET_TXN_TIMEOUT)
flags: SET_LOCK_TIMEOUT SET_TXN_TIMEOUT
$bool = $txn->failed
# see db_txn_finish documentation, above
DBC/cursor methods
Methods available on DBC/$dbc handles:
DESTROY (DBC_ornull *dbc)
CODE:
if (dbc)
dbc->c_close (dbc);
$int = $cursor->set_priority ($priority = PRIORITY_*) (v4.6)
Example:
my $c = $db->cursor;
for (;;) {
db_c_get $c, my $key, my $data, BDB::NEXT;
warn "<$!,$key,$data>";
last if $!;
}
db_c_close $c;
DB_SEQUENCE/sequence methods
Methods available on DB_SEQUENCE/$seq handles:
DESTROY (DB_SEQUENCE_ornull *seq)
CODE:
if (seq)
seq->close (seq, 0);
$int = $seq->initial_value (db_seq_t value)
$int = $seq->set_cachesize (U32 size)
$int = $seq->set_flags (U32 flags)
flags: SEQ_DEC SEQ_INC SEQ_WRAP
$int = $seq->set_range (db_seq_t min, db_seq_t max)
Example:
my $seq = $db->sequence;
db_sequence_open $seq, undef, "seq", BDB::CREATE;
perl v5.10.0 2009-07-17 8
BDB(3) User Contributed Perl Documentation BDB(3)
db_sequence_get $seq, undef, 1, my $value;
SUPPORT FUNCTIONS
EVENT PROCESSING AND EVENT LOOP INTEGRATION
$msg = BDB::strerror [$errno]
Returns the string corresponding to the given errno
value. If no argument is given, use $!.
Note that the BDB module also patches the $! variable
directly, so you should be able to get a bdb error
string by simply stringifying $!.
$fileno = BDB::poll_fileno
Return the request result pipe file descriptor. This
filehandle must be polled for reading by some
mechanism outside this module (e.g. Event or select,
see below or the SYNOPSIS). If the pipe becomes
readable you have to call "poll_cb" to check the
results.
See "poll_cb" for an example.
BDB::poll_cb
Process some outstanding events on the result pipe.
You have to call this regularly. Returns the number of
events processed. Returns immediately when no events
are outstanding. The amount of events processed
depends on the settings of "BDB::max_poll_req" and
"BDB::max_poll_time".
If not all requests were processed for whatever
reason, the filehandle will still be ready when
"poll_cb" returns.
Example: Install an Event watcher that automatically
calls BDB::poll_cb with high priority:
Event->io (fd => BDB::poll_fileno,
poll => 'r', async => 1,
cb => \&BDB::poll_cb);
BDB::max_poll_reqs $nreqs
BDB::max_poll_time $seconds
These set the maximum number of requests (default 0,
meaning infinity) that are being processed by
"BDB::poll_cb" in one call, respectively the maximum
amount of time (default 0, meaning infinity) spent in
"BDB::poll_cb" to process requests (more correctly the
mininum amount of time "poll_cb" is allowed to use).
Setting "max_poll_time" to a non-zero value creates an
overhead of one syscall per request processed, which
perl v5.10.0 2009-07-17 9
BDB(3) User Contributed Perl Documentation BDB(3)
is not normally a problem unless your callbacks are
really really fast or your OS is really really slow (I
am not mentioning Solaris here). Using "max_poll_reqs"
incurs no overhead.
Setting these is useful if you want to ensure some
level of interactiveness when perl is not fast enough
to process all requests in time.
For interactive programs, values such as 0.01 to 0.1
should be fine.
Example: Install an EV watcher that automatically
calls BDB::poll_cb with low priority, to ensure that
other parts of the program get the CPU sometimes even
under high load.
# try not to spend much more than 0.1s in poll_cb
BDB::max_poll_time 0.1;
my $bdb_poll = EV::io BDB::poll_fileno, EV::READ, \&BDB::poll_cb);
BDB::poll_wait
If there are any outstanding requests and none of them
in the result phase, wait till the result filehandle
becomes ready for reading (simply does a "select" on
the filehandle. This is useful if you want to
synchronously wait for some requests to finish).
See "nreqs" for an example.
BDB::poll
Waits until some requests have been handled.
Returns the number of requests processed, but is
otherwise strictly equivalent to:
BDB::poll_wait, BDB::poll_cb
BDB::flush
Wait till all outstanding BDB requests have been
handled.
Strictly equivalent to:
BDB::poll_wait, BDB::poll_cb
while BDB::nreqs;
VERSION CHECKING
BerkeleyDB comes in various versions, many of them have
minor incompatibilities. This means that traditional "at
least version x.x" checks are often not sufficient.
perl v5.10.0 2009-07-17 10
BDB(3) User Contributed Perl Documentation BDB(3)
Example: set the log_autoremove option in a way compatible
with <v4.7 and v4.7. Note the use of & on the constants to
avoid triggering a compiletime bug when the symbol isn't
available.
$DB_ENV->set_flags (&BDB::LOG_AUTOREMOVE ) if BDB::VERSION v0, v4.7;
$DB_ENV->log_set_config (&BDB::LOG_AUTO_REMOVE) if BDB::VERSION v4.7;
BDB::VERSION
The "BDB::VERSION" function, when called without
arguments, returns the Berkeley DB version as a
v-string (usually with 3 components). You should use
"lt" and "ge" operators exclusively to make
comparisons.
Example: check for at least version 4.7.
BDB::VERSION ge v4.7 or die;
BDB::VERSION min-version
Returns true if the BDB version is at least the given
version (specified as a v-string), false otherwise.
Example: check for at least version 4.5.
BDB::VERSION v4.7 or die;
BDB::VERSION min-version, max-version
Returns true of the BDB version is at least version
"min-version" (specify "undef" or "v0" for any minimum
version) and less then "max-version".
Example: check wether version is strictly less then
v4.7.
BDB::VERSION v0, v4.7
or die "version 4.7 is not yet supported";
CONTROLLING THE NUMBER OF THREADS
BDB::min_parallel $nthreads
Set the minimum number of BDB threads to $nthreads.
The current default is 8, which means eight
asynchronous operations can execute concurrently at
any one time (the number of outstanding requests,
however, is unlimited).
BDB starts threads only on demand, when an BDB request
is queued and no free thread exists. Please note that
queueing up a hundred requests can create demand for a
hundred threads, even if it turns out that everything
is in the cache and could have been processed faster
by a single thread.
perl v5.10.0 2009-07-17 11
BDB(3) User Contributed Perl Documentation BDB(3)
It is recommended to keep the number of threads
relatively low, as some Linux kernel versions will
scale negatively with the number of threads (higher
parallelity => MUCH higher latency). With current
Linux 2.6 versions, 4-32 threads should be fine.
Under most circumstances you don't need to call this
function, as the module selects a default that is
suitable for low to moderate load.
BDB::max_parallel $nthreads
Sets the maximum number of BDB threads to $nthreads.
If more than the specified number of threads are
currently running, this function kills them. This
function blocks until the limit is reached.
While $nthreads are zero, aio requests get queued but
not executed until the number of threads has been
increased again.
This module automatically runs "max_parallel 0" at
program end, to ensure that all threads are killed and
that there are no outstanding requests.
Under normal circumstances you don't need to call this
function.
BDB::max_idle $nthreads
Limit the number of threads (default: 4) that are
allowed to idle (i.e., threads that did not get a
request to process within 10 seconds). That means if a
thread becomes idle while $nthreads other threads are
also idle, it will free its resources and exit.
This is useful when you allow a large number of
threads (e.g. 100 or 1000) to allow for extremely high
load situations, but want to free resources under
normal circumstances (1000 threads can easily consume
30MB of RAM).
The default is probably ok in most situations,
especially if thread creation is fast. If thread
creation is very slow on your system you might want to
use larger values.
$oldmaxreqs = BDB::max_outstanding $maxreqs
This is a very bad function to use in interactive
programs because it blocks, and a bad way to reduce
concurrency because it is inexact: Better use an
"aio_group" together with a feed callback.
Sets the maximum number of outstanding requests to
$nreqs. If you to queue up more than this number of
requests, the next call to the "poll_cb" (and
perl v5.10.0 2009-07-17 12
BDB(3) User Contributed Perl Documentation BDB(3)
"poll_some" and other functions calling "poll_cb")
function will block until the limit is no longer
exceeded.
The default value is very large, so there is no
practical limit on the number of outstanding requests.
You can still queue as many requests as you want.
Therefore, "max_oustsanding" is mainly useful in
simple scripts (with low values) or as a stop gap to
shield against fatal memory overflow (with large
values).
$old_cb = BDB::set_sync_prepare $cb
Sets a callback that is called whenever a request is
created without an explicit callback. It has to return
two code references. The first is used as the request
callback (it should save the return status), and the
second is called to wait until the first callback has
been called (it must set $! to the return status).
This mechanism can be used to include BDB into other
event mechanisms, such as Coro::BDB.
To allow other, callback-based, events to be executed
while callback-less ones are run, you could use this
sync prepare function:
sub {
my $status;
(
sub { $status = $! },
sub { BDB::poll while !defined $status; $! = $status },
)
}
It works by polling for results till the request has
finished and then sets $! to the return value. This
means that if you don't use a callback, BDB would
simply fall back to synchronous operations.
By default, or if the sync prepare function is set to
"undef", is to execute callback-less BDB requests in
the foreground thread, setting $! to the return
value, without polling for other events.
STATISTICAL INFORMATION
BDB::nreqs
Returns the number of requests currently in the ready,
execute or pending states (i.e. for which their
callback has not been invoked yet).
perl v5.10.0 2009-07-17 13
BDB(3) User Contributed Perl Documentation BDB(3)
Example: wait till there are no outstanding requests
anymore:
BDB::poll_wait, BDB::poll_cb
while BDB::nreqs;
BDB::nready
Returns the number of requests currently in the ready
state (not yet executed).
BDB::npending
Returns the number of requests currently in the
pending state (executed, but not yet processed by
poll_cb).
COMMON PITFALLS
Unexpected Crashes
Remember that, by default, BDB will execute requests in
parallel, in somewhat random order. That means that it is
easy to run a "db_get" request on thesa me database as a
concurrent "db_close" request, leading to a crash, silent
data corruption, eventually the next world war on
terrorism.
If you only ever use foreground requests (without a
callback), this will not be an issue.
Unexpected Freezes or Deadlocks
Remember that, by default, BDB will execute requests in
parallel, which easily leads to deadlocks (even concurrent
put's on the same database can deadlock).
You either need to run deadlock detection (and handle the
resulting errors), or make sure only one process ever
updates the database, ine one thread, e.g. by using only
foreground requests (without a callback).
FORK BEHAVIOUR
This module should do "the right thing" when the process
using it forks:
Before the fork, BDB enters a quiescent state where no
requests can be added in other threads and no results will
be processed. After the fork the parent simply leaves the
quiescent state and continues request/result processing,
while the child frees the request/result queue (so that
the requests started before the fork will only be handled
in the parent). Threads will be started on demand until
the limit set in the parent process has been reached
again.
In short: the parent will, after a short pause, continue
perl v5.10.0 2009-07-17 14
BDB(3) User Contributed Perl Documentation BDB(3)
as if fork had not been called, while the child will act
as if BDB has not been used yet.
Win32 note: there is no fork on win32, and perls emulation
of it is too broken to be supported, so do not use BDB in
a windows pseudo-fork, better yet, switch to a more
capable platform.
MEMORY USAGE
Per-request usage:
Each aio request uses - depending on your architecture -
around 100-200 bytes of memory. In addition, stat requests
need a stat buffer (possibly a few hundred bytes), readdir
requires a result buffer and so on. Perl scalars and other
data passed into aio requests will also be locked and will
consume memory till the request has entered the done
state.
This is not awfully much, so queuing lots of requests is
not usually a problem.
Per-thread usage:
In the execution phase, some aio requests require more
memory for temporary buffers, and each thread requires a
stack and other data structures (usually around 16k-128k,
depending on the OS).
WIN32 FILENAMES/DATABASE NAME MESS
Perl on Win32 supports only ASCII filenames (the reason is
that it abuses an internal flag to store wether a filename
is Unicode or ANSI, but that flag is used for somethign
else in the perl core, so there is no way to detect wether
a filename is ANSI or Unicode-encoded). The BDB module
tries to work around this issue by assuming that the
filename is an ANSI filename and BDB was built for unicode
support.
KNOWN BUGS
Known bugs will be fixed in the next release, except:
If you use a transaction in any request, and the request returns
with an operating system error or DB_LOCK_NOTGRANTED, the internal
TXN_DEADLOCK flag will be set on the transaction. See C<db_txn_finish>,
above.
SEE ALSO
AnyEvent::BDB (event loop integration), Coro::BDB (more
natural syntax), IO::AIO (nice to have).
AUTHOR
Marc Lehmann <schmorpATschmorp.de>
http://home.schmorp.de/
perl v5.10.0 2009-07-17 15
BDB(3) User Contributed Perl Documentation BDB(3)
perl v5.10.0 2009-07-17 16
|