|
DB_ENV->remove
|
|
#include <db.h>
int
DB_ENV->remove(DB_ENV *, char *db_home, u_int32_t flags);
Description
The DB_ENV->remove function destroys a Berkeley DB environment if it is not
currently in use. The environment regions, including any backing files,
are removed. Any log or database files and the environment directory are
not removed.
The db_home argument to DB_ENV->remove is described in
Berkeley DB File Naming.
If there are processes that have called DB_ENV->open without
calling DB_ENV->close (that is, there are processes currently
using the environment), DB_ENV->remove will fail without further
action unless the DB_FORCE flag is set, in which case
DB_ENV->remove will attempt to remove the environment, regardless
of any processes still using it.
The result of attempting to forcibly destroy the environment when it is
in use is unspecified. Processes using an environment often maintain open
file descriptors for shared regions within it. On UNIX systems, the
environment removal will usually succeed, and processes that have already
joined the region will continue to run in that region without change.
However, processes attempting to join the environment will either fail
or create new regions. On other systems in which the unlink(2) system call will fail if any process has an open file descriptor for
the file (for example Windows/NT), the region removal will fail.
Calling DB_ENV->remove should not be necessary for most applications
because the Berkeley DB environment is cleaned up as part of normal database
recovery procedures. However, applications may want to call
DB_ENV->remove as part of application shut down to free up system
resources. For example, if the DB_SYSTEM_MEM flag was specified
to DB_ENV->open, it may be useful to call DB_ENV->remove in
order to release system shared memory segments that have been allocated.
Or, on architectures in which mutexes require allocation of underlying
system resources, it may be useful to call DB_ENV->remove in order
to release those resources. Alternatively, if recovery is not required
because no database state is maintained across failures, and no system
resources need to be released, it is possible to clean up an environment
by simply removing all the Berkeley DB files in the database environment's
directories.
The flags value must be set to 0 or by bitwise inclusively OR'ing together one or
more of the following values:
- DB_FORCE
- If the DB_FORCE flag is set, the environment is removed, regardless
of any processes that may still using it, and no locks are acquired
during this process. (Generally, the DB_FORCE flag is
specified only when applications were unable to shut down cleanly, and there
is a risk that an application may have died holding a Berkeley DB lock.)
- DB_USE_ENVIRON
- The Berkeley DB process' environment may be permitted to specify information
to be used when naming files; see Berkeley DB File Naming. Because permitting users to specify which files
are used can create security problems, environment information will be
used in file naming for all users only if the DB_USE_ENVIRON flag is
set.
- DB_USE_ENVIRON_ROOT
- The Berkeley DB process' environment may be permitted to specify information
to be used when naming files; see Berkeley DB File Naming. Because permitting users to specify which files
are used can create security problems, if the DB_USE_ENVIRON_ROOT flag
is set, environment information will be used for file naming only for
users with appropriate permissions (for example, users with a user-ID
of 0 on UNIX systems).
In multithreaded applications, only a single thread may call
DB_ENV->remove.
A DB_ENV handle that has already been used to open an environment
should not be used to call the DB_ENV->remove function; a new
DB_ENV handle should be created for that purpose.
After DB_ENV->remove has been called, regardless of its return,
the Berkeley DB environment handle may not be accessed again.
The DB_ENV->remove function returns a non-zero error value on failure and 0 on success.
Errors
- EBUSY
- The shared memory region was in use and the force flag was not set.
The DB_ENV->remove function may fail and return a non-zero error for errors specified for other Berkeley DB and C library or system functions.
If a catastrophic error has occurred, the DB_ENV->remove function may fail and return
DB_RUNRECOVERY, in which case all subsequent Berkeley DB calls will fail
in the same way.
See Also
db_env_create,
DB_ENV->close,
DB_ENV->err, DB_ENV->errx
DB_ENV->open,
DB_ENV->remove,
DB_ENV->set_alloc,
DB_ENV->set_cachesize,
DB_ENV->set_data_dir,
DB_ENV->set_errcall,
DB_ENV->set_errfile,
DB_ENV->set_errpfx,
DB_ENV->set_feedback,
DB_ENV->set_flags,
DB_ENV->set_paniccall,
DB_ENV->set_recovery_init,
DB_ENV->set_rpc_server,
DB_ENV->set_shm_key,
DB_ENV->set_tas_spins,
DB_ENV->set_tmp_dir,
DB_ENV->set_timeout,
DB_ENV->set_verbose,
db_strerror
and
db_version.
Copyright Sleepycat Software
|