What other services does Berkeley DB provide?
           
         
       
      Berkeley DB also provides core database services to developers.  These
services include:
      
        
          - 
            Page cache management:
          
- The page cache provides fast access to a cache of database pages,
handling the I/O associated with the cache to ensure that dirty pages
are written back to the file system and that new pages are allocated on
demand.  Applications may use the Berkeley DB shared memory buffer manager to
serve their own files and pages.
- 
            Transactions and logging:
          
- The transaction and logging systems provide recoverability and atomicity
for multiple database operations. The transaction system uses two-phase
locking and write-ahead logging protocols to ensure that database
operations may be undone or redone in the case of application or system
failure.  Applications may use Berkeley DB transaction and logging subsystems
to protect their own data structures and operations from application or
system failure.
- 
            Locking:
          
- The locking system provides multiple reader or single writer access to
objects.  The Berkeley DB access methods use the locking system to acquire
the right to read or write database pages.  Applications may use the
Berkeley DB locking subsystem to support their own locking needs.
 
      By combining the page cache, transaction, locking, and logging systems,
Berkeley DB provides the same services found in much larger, more complex and
more expensive database systems.  Berkeley DB supports multiple simultaneous
readers and writers and guarantees that all changes are recoverable, even
in the case of a catastrophic hardware failure during a database update.
      Developers may select some or all of the core database services for any
access method or database.  Therefore, it is possible to choose the
appropriate storage structure and the right degrees of concurrency and
recoverability for any application.  In addition, some of the subsystems
(for example, the Locking subsystem) can be called separately from the
Berkeley DB access method.  As a result, developers can integrate non-database
objects into their transactional applications using Berkeley DB.