- Berkeley DB Reference Guide:
- Access Methods
|
|
Selecting a Queue extent size
In Queue databases, records are allocated sequentially and directly
mapped to an offset within the file storage for the database. As
records are deleted from the Queue, pages will become empty and will
not be reused in normal queue operations. To facilitate the reclamation
of disk space a Queue may be partitioned into extents. Each extent is
kept in a separate physical file.
Extent files are automatically created as needed and marked for deletion
when the head of the queue moves off the extent. The extent will not
be deleted until all processes close the extent. In addition, Berkeley DB
caches a small number of extents that have been recently used; this may
delay when an extent will be deleted. The number of extents left open
depends on queue activity.
The extent size specifies the number of pages that make up each extent.
By default, if no extent size is specified, the Queue resides in a
single file and disk space is not reclaimed. In choosing an extent size
there is a tradeoff between the amount of disk space used and the
overhead of creating and deleting files. If the extent size is too
small, the system will pay a performance penalty, creating and deleting
files frequently. In addition, if the active part of the queue spans
many files, all those files will need to be open at the same time,
consuming system and process file resources.
Copyright Sleepycat Software
|