Berkeley DB: db_deadlock
Полезная информация


db_deadlock [-vw]
    [-a m | o | y] [-h home] [-L file] [-t sec]


The db_deadlock utility traverses the database lock structures and aborts a transaction each time it detects a deadlock. This utility should be run as a background daemon whenever multiple threads or processes are using locking. By default, a random transaction involved in the deadlock is aborted.

The options are as follows:

When a deadlock is detected, abort the oldest (o) transaction, the youngest (y) transaction, or the transaction with the minimum number of locks (m).

Specify a home directory for the database.

Log the execution of the db_deadlock utility to the specified file in the following format, where ### is the process ID, and the date is the time the utility starting running.

    db_deadlock: ### Wed Jun 15 01:23:45 EDT 1995

This file will be removed if the db_deadlock utility exits gracefully.

Initiate a pass over the database locks at least every sec seconds.

Run in verbose mode, generating messages each time the detector runs.

Make a single pass over the database locks every time a process is forced to wait for a lock.

At least one of the -t and -w options must be specified.

The db_deadlock utility attaches to one or more of the Berkeley DB shared memory regions. In order to avoid region corruption, it should always be given the chance to detach and exit gracefully. To cause db_deadlock to clean up after itself and exit, send it an interrupt signal (SIGINT).

The db_deadlock utility does not attempt to create the Berkeley DB shared memory regions if they do not already exist. The application which creates the region should be started first, and then, once the region is created, the db_deadlock utility should be started.

The lock_detect function is the underlying function used by the db_deadlock utility. See the db_deadlock utility source code for an example of using lock_detect in a POSIX 1003.1 environment.

The db_deadlock utility exits 0 on success, and >0 if an error occurs.

Environment Variables

If the -h option is not specified and the environment variable DB_HOME is set, it is used as the path of the database home, as described in db_appinit.

See Also

db_archive, db_checkpoint, db_deadlock, db_dump, db_load, db_recover, and db_stat.