UPDATEDB
Section: User Commands (1)
Index
Return to Main Contents
NAME
updatedb - update a file name database
SYNOPSIS
updatedb [options]
DESCRIPTION
This manual page
documents the GNU version of
updatedb,
which updates file name databases used by GNU
locate.
The file name databases contain lists of files that were in
particular directory trees when the databases were last updated.
The file name of the default database is determined when locate
and updatedb are configured and installed. The frequency with
which the databases are updated and the directories for which they
contain entries depend on how often updatedb is run, and with
which arguments.
In networked environments, it often makes sense to build a database at
the root of each filesystem, containing the entries for that filesystem.
updatedb
is then run for each filesystem on the fileserver where that
filesystem is on a local disk, to prevent thrashing the network.
Users can select which databases locate searches using an
environment variable or command line option; see locate(1).
Databases can not be concatenated together.
Versions of locate prior to 4.2.31 fail to correctly handle long file
names in the old databse format, but the default database format
(called LOCATE02) is not affected by this problem. All versions of
locate
since version 4.0 support the new LOCATE02 format. The old database
format also cannot correctly represent non-ASCII characters.
OPTIONS
- --findoptions='-option1 -option2...'
-
Global options to pass on to find.
The environment variable FINDOPTIONS also sets this value.
Default is none.
- --localpaths='path1 path2...'
-
Non-network directories to put in the database.
Default is /.
- --netpaths='path1 path2...'
-
Network (NFS, AFS, RFS, etc.) directories to put in the database.
The environment variable NETPATHS also sets this value.
Default is none.
- --prunepaths='path1 path2...'
-
Directories to not put in the database, which would otherwise be.
Remove any trailing slashes from the path names, otherwise
updatedb
won't recognise the paths you want to omit (because it uses them as
regular expression patterns).
The environment variable PRUNEPATHS also sets this value.
Default is /tmp /usr/tmp /var/tmp /afs.
- --prunefs='path...'
-
File systems to not put in the database, which would otherwise be.
Note that files are pruned when a file system is reached;
Any file system mounted under an undesired file system will be
ignored.
The environment variable
PRUNEFS also sets this value.
Default is nfs NFS proc.
- --output=dbfile
-
The database file to build.
Default is system-dependent. In Debian GNU/Linux, the default
is /var/cache/locate/locatedb.
- --localuser=user
-
The user to search non-network directories as, using su(1).
Default is to search the non-network directories as the current user.
You can also use the environment variable LOCALUSER to set this user.
- --netuser=user
-
The user to search network directories as, using su(1).
Default is daemon.
You can also use the environment variable NETUSER to set this user.
- --old-format
-
Create the database in the old format instead of the new one. Avoid
using this option as older versions of locate are susceptible to a
buffer overrun when reading old-format databases. The old fatabase
format is also incapable of correctly representing non-ASCII
characters.
- --version
-
Print the version number of
updatedb
and exit.
- --help
-
Print a summary of the options to
updatedb
and exit.
SEE ALSO
find(1), locate(1), locatedb(5), xargs(1)
Finding Files (on-line in Info, or printed)
BUGS
All versions of GNU locate prior to 4.2.31 fail to correctly handle
long (roughly, over 1024 bytes) filenames in old-format databases.
This can lead to a heap buffer overrun and it a potential security
issue. Verions 4.3.0 to 4.3.6 are also affected by the bug.
Databases in the default LOCATE02 format are correctly handled.
The
updatedb
program correctly handles filenames containing newlines,
but only if the system's sort command has a working
-z
option. If you suspect that
locate
may need to return filenames containing newlines, consider using its
--null
option.
The best way to report a bug is to use the form at
http://savannah.gnu.org/bugs/?group=findutils.
The reason for this is that you will then be able to track progress in
fixing the problem. Other comments about updatedb(1) and about
the findutils package in general can be sent to the
bug-findutils
mailing list. To join the list, send email to
[email protected].
Index
- NAME
-
- SYNOPSIS
-
- DESCRIPTION
-
- OPTIONS
-
- SEE ALSO
-
- BUGS
-
This document was created by
using the manual pages.
Time: 23:07:12 GMT, May 09, 2009