mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-12 10:54:48 +08:00
35655c056f
Old code applied sync flags to store(), however supported DBMs require such flags to be specified during open(). The new code now applies flags in ldbm_cache_open (which calls ldbm_open). ldbm_cache_close() now calls ldbm_sync(). This will force a updating of on-disk contents after each LDAP operation. The old code either failed to sync the on-disk contents until close or synced on every store. Per LDBM operation syncing *should* be safe enough... real data safety requires transactions. Removed nosync option from BDB2 as it is not compatible with txn support. Also added code to disable DBM level locking as slapd is only process acessing the databases (dbnolocking).
157 lines
4.1 KiB
C
157 lines
4.1 KiB
C
/* back-ldbm.h - ldap ldbm back-end header file */
|
|
/* $OpenLDAP$ */
|
|
/*
|
|
* Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved.
|
|
* COPYING RESTRICTIONS APPLY, see COPYRIGHT file
|
|
*/
|
|
|
|
#ifndef _BACK_LDBM_H_
|
|
#define _BACK_LDBM_H_
|
|
|
|
#include "ldbm.h"
|
|
|
|
LDAP_BEGIN_DECL
|
|
|
|
#define DEFAULT_CACHE_SIZE 1000
|
|
|
|
#ifdef HAVE_BERKELEY_DB2
|
|
# define DEFAULT_DBCACHE_SIZE (100 * DEFAULT_DB_PAGE_SIZE)
|
|
#else
|
|
# define DEFAULT_DBCACHE_SIZE 100000
|
|
#endif
|
|
|
|
#define DEFAULT_DB_DIRECTORY "/usr/tmp"
|
|
#define DEFAULT_MODE 0600
|
|
|
|
#define SUBLEN 3
|
|
|
|
#define DN_BASE_PREFIX '='
|
|
#define DN_ONE_PREFIX '@'
|
|
#define DN_SUBTREE_PREFIX '?'
|
|
|
|
#define SLAPD_FILTER_DN_ONE ((ber_tag_t) -2)
|
|
#define SLAPD_FILTER_DN_SUBTREE ((ber_tag_t) -3)
|
|
|
|
/*
|
|
* there is a single index for each attribute. these prefixes ensure
|
|
* that there is no collision among keys.
|
|
*/
|
|
#define EQ_PREFIX '=' /* prefix for equality keys */
|
|
#define APPROX_PREFIX '~' /* prefix for approx keys */
|
|
#define SUB_PREFIX '*' /* prefix for substring keys */
|
|
#define CONT_PREFIX '\\' /* prefix for continuation keys */
|
|
|
|
/* allow 3 characters per byte + PREFIX + EOS */
|
|
#define CONT_SIZE ( sizeof(long)*3 + 1 + 1 )
|
|
|
|
#define UNKNOWN_PREFIX '?' /* prefix for unknown keys */
|
|
|
|
#define DEFAULT_BLOCKSIZE 8192
|
|
|
|
/*
|
|
* This structure represents an id block on disk and an id list
|
|
* in core.
|
|
*
|
|
* The fields have the following meanings:
|
|
*
|
|
* b_nmax maximum number of ids in this block. if this is == ALLIDSBLOCK,
|
|
* then this block represents all ids.
|
|
* b_nids current number of ids in use in this block. if this
|
|
* is == INDBLOCK, then this block is an indirect block
|
|
* containing a list of other blocks containing actual ids.
|
|
* the list is terminated by an id of NOID.
|
|
* b_ids a list of the actual ids themselves
|
|
*/
|
|
|
|
typedef ID ID_BLOCK;
|
|
|
|
#define ID_BLOCK_NMAX_OFFSET 0
|
|
#define ID_BLOCK_NIDS_OFFSET 1
|
|
#define ID_BLOCK_IDS_OFFSET 2
|
|
|
|
/* all ID_BLOCK macros operate on a pointer to a ID_BLOCK */
|
|
|
|
#define ID_BLOCK_NMAX(b) ((b)[ID_BLOCK_NMAX_OFFSET])
|
|
#define ID_BLOCK_NIDS(b) ((b)[ID_BLOCK_NIDS_OFFSET])
|
|
#define ID_BLOCK_ID(b, n) ((b)[ID_BLOCK_IDS_OFFSET+(n)])
|
|
|
|
#define ID_BLOCK_NOID(b, n) (ID_BLOCK_ID((b),(n)) == NOID)
|
|
|
|
#define ID_BLOCK_ALLIDS_VALUE 0
|
|
#define ID_BLOCK_ALLIDS(b) (ID_BLOCK_NMAX(b) == ID_BLOCK_ALLIDS_VALUE)
|
|
|
|
#define ID_BLOCK_INDIRECT_VALUE 0
|
|
#define ID_BLOCK_INDIRECT(b) (ID_BLOCK_NIDS(b) == ID_BLOCK_INDIRECT_VALUE)
|
|
|
|
/* for the in-core cache of entries */
|
|
typedef struct ldbm_cache {
|
|
int c_maxsize;
|
|
int c_cursize;
|
|
Avlnode *c_dntree;
|
|
Avlnode *c_idtree;
|
|
Entry *c_lruhead; /* lru - add accessed entries here */
|
|
Entry *c_lrutail; /* lru - rem lru entries from here */
|
|
ldap_pvt_thread_mutex_t c_mutex;
|
|
} Cache;
|
|
|
|
#define CACHE_READ_LOCK 0
|
|
#define CACHE_WRITE_LOCK 1
|
|
|
|
/* for the cache of open index files */
|
|
typedef struct ldbm_dbcache {
|
|
int dbc_refcnt;
|
|
int dbc_maxids;
|
|
int dbc_maxindirect;
|
|
time_t dbc_lastref;
|
|
long dbc_blksize;
|
|
char *dbc_name;
|
|
LDBM dbc_db;
|
|
} DBCache;
|
|
|
|
/* for the cache of attribute information (which are indexed, etc.) */
|
|
typedef struct ldbm_attrinfo {
|
|
char *ai_type; /* type name (cn, sn, ...) */
|
|
int ai_indexmask; /* how the attr is indexed */
|
|
#define INDEX_PRESENCE 0x0001
|
|
#define INDEX_EQUALITY 0x0002
|
|
#define INDEX_APPROX 0x0004
|
|
#define INDEX_SUB 0x0008
|
|
#define INDEX_UNKNOWN 0x0010
|
|
#define INDEX_FROMINIT 0x1000
|
|
int ai_syntaxmask; /* what kind of syntax */
|
|
/* ...from slap.h...
|
|
#define SYNTAX_CIS 0x01
|
|
#define SYNTAX_CES 0x02
|
|
#define SYNTAX_BIN 0x04
|
|
... etc. ...
|
|
*/
|
|
} AttrInfo;
|
|
|
|
#define MAXDBCACHE 16
|
|
|
|
struct ldbminfo {
|
|
ID li_nextid;
|
|
ldap_pvt_thread_mutex_t li_nextid_mutex;
|
|
ldap_pvt_thread_mutex_t li_root_mutex;
|
|
ldap_pvt_thread_mutex_t li_add_mutex;
|
|
int li_mode;
|
|
char *li_directory;
|
|
Cache li_cache;
|
|
Avlnode *li_attrs;
|
|
int li_dblocking; /* lock databases */
|
|
int li_dbwritesync; /* write sync */
|
|
int li_dbcachesize;
|
|
DBCache li_dbcache[MAXDBCACHE];
|
|
ldap_pvt_thread_mutex_t li_dbcache_mutex;
|
|
ldap_pvt_thread_cond_t li_dbcache_cv;
|
|
#ifdef HAVE_BERKELEY_DB2
|
|
DB_ENV li_db_env;
|
|
#endif
|
|
};
|
|
|
|
LDAP_END_DECL
|
|
|
|
#include "proto-back-ldbm.h"
|
|
|
|
#endif /* _back_ldbm_h_ */
|