Skip to content
GitLab
Explore
Sign in
Register
Primary navigation
Search or go to…
Project
O
OpenLDAP
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Requirements
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Locked files
Build
Pipelines
Jobs
Pipeline schedules
Test cases
Artifacts
Deploy
Releases
Package registry
Container Registry
Model registry
Operate
Environments
Terraform modules
Monitor
Incidents
Service Desk
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Code review analytics
Issue analytics
Insights
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
Community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Dragoș Haiduc
OpenLDAP
Commits
bff244da
Commit
bff244da
authored
20 years ago
by
Howard Chu
Browse files
Options
Downloads
Patches
Plain Diff
Add dbconfig directive for creating/writing the DB_CONFIG file
parent
04f6efbe
No related branches found
No related tags found
No related merge requests found
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
servers/slapd/back-bdb/back-bdb.h
+4
-0
4 additions, 0 deletions
servers/slapd/back-bdb/back-bdb.h
servers/slapd/back-bdb/config.c
+92
-14
92 additions, 14 deletions
servers/slapd/back-bdb/config.c
servers/slapd/back-bdb/init.c
+28
-0
28 additions, 0 deletions
servers/slapd/back-bdb/init.c
with
124 additions
and
14 deletions
servers/slapd/back-bdb/back-bdb.h
+
4
−
0
View file @
bff244da
...
...
@@ -191,6 +191,10 @@ struct bdb_info {
ldap_pvt_thread_rdwr_t
bi_idl_tree_rwlock
;
ldap_pvt_thread_mutex_t
bi_idl_tree_lrulock
;
alock_info_t
bi_alock_info
;
char
*
bi_db_config_path
;
BerVarray
bi_db_config
;
int
bi_db_is_open
;
int
bi_db_has_config
;
};
#define bi_id2entry bi_databases[BDB_ID2ENTRY]
...
...
This diff is collapsed.
Click to expand it.
servers/slapd/back-bdb/config.c
+
92
−
14
View file @
bff244da
...
...
@@ -23,6 +23,8 @@
#include
"config.h"
#include
"lutil.h"
#ifdef DB_DIRTY_READ
# define SLAP_BDB_ALLOW_DIRTY_READ
#endif
...
...
@@ -33,6 +35,8 @@ static ConfigDriver bdb_cf_oc, bdb_cf_gen;
enum
{
BDB_CHKPT
=
1
,
BDB_CONFIG
,
BDB_DIRECTORY
,
BDB_NOSYNC
,
BDB_DIRTYR
,
BDB_INDEX
,
...
...
@@ -43,25 +47,28 @@ enum {
static
ConfigTable
bdbcfg
[]
=
{
{
""
,
""
,
0
,
0
,
0
,
ARG_MAGIC
,
bdb_cf_oc
,
NULL
,
NULL
,
NULL
},
{
"directory"
,
"dir"
,
2
,
2
,
0
,
ARG_STRING
|
ARG_OFFSET
,
(
void
*
)
offsetof
(
struct
bdb_info
,
bi_dbenv_home
),
"( OLcfgAt:1.1 NAME 'dbDirectory' "
{
"directory"
,
"dir"
,
2
,
2
,
0
,
ARG_STRING
|
ARG_MAGIC
|
BDB_DIRECTORY
,
bdb_cf_gen
,
"( OLcfgAt:1.1 NAME 'dbDirectory' "
"DESC 'Directory for database content' "
"EQUALITY caseIgnoreMatch "
"SYNTAX OMsDirectoryString )"
,
NULL
,
NULL
},
"SYNTAX OMsDirectoryString
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"cachesize"
,
"size"
,
2
,
2
,
0
,
ARG_INT
|
ARG_OFFSET
,
(
void
*
)
offsetof
(
struct
bdb_info
,
bi_cache
.
c_maxsize
),
"( OLcfgAt:1.2 NAME 'dbCacheSize' "
"DESC 'Entry cache size in entries' "
"SYNTAX OMsInteger )"
,
NULL
,
NULL
},
"SYNTAX OMsInteger
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"checkpoint"
,
"kbyte> <min"
,
3
,
3
,
0
,
ARG_MAGIC
|
BDB_CHKPT
,
bdb_cf_gen
,
"( OLcfgAt:1.3 NAME 'dbCheckpoint' "
"DESC 'Database checkpoint interval in kbytes and minutes' "
"SYNTAX OMsDirectoryString SINGLE-VALUE )"
,
NULL
,
NULL
},
{
"dbconfig"
,
"DB_CONFIG setting"
,
3
,
0
,
0
,
ARG_MAGIC
|
BDB_CONFIG
,
bdb_cf_gen
,
"( OLcfgAt:1.13 NAME 'dbConfig' "
"DESC 'BerkeleyDB DB_CONFIG configuration directives' "
"SYNTAX OMsDirectoryString )"
,
NULL
,
NULL
},
{
"dbnosync"
,
NULL
,
1
,
2
,
0
,
ARG_ON_OFF
|
ARG_MAGIC
|
BDB_NOSYNC
,
bdb_cf_gen
,
"( OLcfgAt:1.4 NAME 'dbNoSync' "
"DESC 'Disable synchronous database writes' "
"SYNTAX OMsBoolean )"
,
NULL
,
NULL
},
"SYNTAX OMsBoolean
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"dirtyread"
,
NULL
,
1
,
2
,
0
,
#ifdef SLAP_BDB_ALLOW_DIRTY_READ
ARG_ON_OFF
|
ARG_MAGIC
|
BDB_DIRTYR
,
bdb_cf_gen
,
...
...
@@ -70,12 +77,12 @@ static ConfigTable bdbcfg[] = {
#endif
"( OLcfgAt:1.5 NAME 'dbDirtyRead' "
"DESC 'Allow reads of uncommitted data' "
"SYNTAX OMsBoolean )"
,
NULL
,
NULL
},
"SYNTAX OMsBoolean
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"idlcachesize"
,
"size"
,
2
,
2
,
0
,
ARG_INT
|
ARG_OFFSET
,
(
void
*
)
offsetof
(
struct
bdb_info
,
bi_idl_cache_max_size
),
"( OLcfgAt:1.6 NAME 'dbIDLcacheSize' "
"DESC 'IDL cache size in IDLs' "
"SYNTAX OMsInteger )"
,
NULL
,
NULL
},
"SYNTAX OMsInteger
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"index"
,
"attr> <[pres,eq,approx,sub]"
,
3
,
3
,
0
,
ARG_MAGIC
|
BDB_INDEX
,
bdb_cf_gen
,
"( OLcfgAt:1.7 NAME 'dbIndex' "
"DESC 'Attribute index parameters' "
...
...
@@ -84,25 +91,25 @@ static ConfigTable bdbcfg[] = {
(
void
*
)
offsetof
(
struct
bdb_info
,
bi_linear_index
),
"( OLcfgAt:1.8 NAME 'dbLinearIndex' "
"DESC 'Index attributes one at a time' "
"SYNTAX OMsBoolean )"
,
NULL
,
NULL
},
"SYNTAX OMsBoolean
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"lockdetect"
,
"policy"
,
2
,
2
,
0
,
ARG_MAGIC
|
BDB_LOCKD
,
bdb_cf_gen
,
"( OLcfgAt:1.9 NAME 'dbLockDetect' "
"DESC 'Deadlock detection algorithm' "
"SYNTAX OMsDirectoryString )"
,
NULL
,
NULL
},
"SYNTAX OMsDirectoryString
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"mode"
,
"mode"
,
2
,
2
,
0
,
ARG_INT
|
ARG_OFFSET
,
(
void
*
)
offsetof
(
struct
bdb_info
,
bi_dbenv_mode
),
"( OLcfgAt:1.10 NAME 'dbMode' "
"DESC 'Unix permissions of database files' "
"SYNTAX OMsInteger )"
,
NULL
,
NULL
},
"SYNTAX OMsInteger
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"searchstack"
,
"depth"
,
2
,
2
,
0
,
ARG_INT
|
ARG_MAGIC
|
BDB_SSTACK
,
bdb_cf_gen
,
"( OLcfgAt:1.11 NAME 'dbSearchStack' "
"DESC 'Depth of search stack in IDLs' "
"SYNTAX OMsInteger )"
,
NULL
,
NULL
},
"SYNTAX OMsInteger
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
"shm_key"
,
"key"
,
2
,
2
,
0
,
ARG_INT
|
ARG_OFFSET
,
(
void
*
)
offsetof
(
struct
bdb_info
,
bi_shm_key
),
"( OLcfgAt:1.12 NAME 'dbShmKey' "
"DESC 'Key for shared memory region' "
"SYNTAX OMsInteger )"
,
NULL
,
NULL
},
"SYNTAX OMsInteger
SINGLE-VALUE
)"
,
NULL
,
NULL
},
{
NULL
,
NULL
,
0
,
0
,
0
,
ARG_IGNORED
,
NULL
,
NULL
,
NULL
,
NULL
}
};
...
...
@@ -113,7 +120,7 @@ static ConfigOCs bdbocs[] = {
"DESC 'BDB backend configuration' "
"SUP olcDatabaseConfig "
"MUST dbDirectory "
"MAY ( dbCacheSize $ dbCheckpoint $ dbNoSync $ "
"MAY ( dbCacheSize $ dbCheckpoint $
dbConfig $
dbNoSync $ "
"dbDirtyRead $ dbIDLcacheSize $ dbIndex $ dbLinearIndex $ "
"dbLockDetect $ dbMode $ dbSearchStack $ dbShmKey ) )"
,
Cft_Database
,
&
bdb_oc
},
...
...
@@ -161,6 +168,29 @@ bdb_cf_gen(ConfigArgs *c)
}
break
;
case
BDB_DIRECTORY
:
if
(
bdb
->
bi_dbenv_home
)
{
c
->
value_string
=
ch_strdup
(
bdb
->
bi_dbenv_home
);
}
else
{
rc
=
1
;
}
break
;
case
BDB_CONFIG
:
if
(
bdb
->
bi_db_config
)
{
int
i
;
struct
berval
bv
;
bv
.
bv_val
=
c
->
log
;
for
(
i
=
0
;
!
BER_BVISNULL
(
&
bdb
->
bi_db_config
[
i
]);
i
++
)
{
bv
.
bv_len
=
sprintf
(
bv
.
bv_val
,
"{%d}%s"
,
i
,
bdb
->
bi_db_config
[
i
].
bv_val
);
value_add_one
(
&
c
->
rvalue_vals
,
&
bv
);
}
}
if
(
!
c
->
rvalue_vals
)
rc
=
1
;
break
;
case
BDB_NOSYNC
:
if
(
bdb
->
bi_dbenv_xflags
&
DB_TXN_NOSYNC
)
c
->
value_int
=
1
;
...
...
@@ -198,6 +228,54 @@ bdb_cf_gen(ConfigArgs *c)
bdb
->
bi_txn_cp_min
=
strtol
(
c
->
argv
[
2
],
NULL
,
0
);
break
;
case
BDB_CONFIG
:
{
char
*
ptr
=
c
->
line
+
STRLENOF
(
"dbconfig"
);
struct
berval
bv
;
while
(
!
isspace
(
*
ptr
))
ptr
++
;
while
(
isspace
(
*
ptr
))
ptr
++
;
/* If we're just starting up...
*/
if
(
!
bdb
->
bi_db_is_open
)
{
FILE
*
f
;
/* If a DB_CONFIG file exists, or we don't know the path
* to the DB_CONFIG file, ignore these directives
*/
if
(
bdb
->
bi_db_has_config
||
!
bdb
->
bi_db_config_path
)
break
;
f
=
fopen
(
bdb
->
bi_db_config_path
,
"a"
);
if
(
f
)
{
/* FIXME: EBCDIC probably needs special handling */
fprintf
(
f
,
"%s
\n
"
,
ptr
);
fclose
(
f
);
}
}
ber_str2bv
(
ptr
,
0
,
1
,
&
bv
);
ber_bvarray_add
(
&
bdb
->
bi_db_config
,
&
bv
);
}
break
;
case
BDB_DIRECTORY
:
{
FILE
*
f
;
char
*
ptr
;
bdb
->
bi_dbenv_home
=
c
->
value_string
;
/* See if a DB_CONFIG file already exists here */
bdb
->
bi_db_config_path
=
ch_malloc
(
strlen
(
bdb
->
bi_dbenv_home
)
+
STRLENOF
(
LDAP_DIRSEP
)
+
STRLENOF
(
"DB_CONFIG"
));
ptr
=
lutil_strcopy
(
bdb
->
bi_db_config_path
,
bdb
->
bi_dbenv_home
);
*
ptr
++
=
LDAP_DIRSEP
[
0
];
strcpy
(
ptr
,
"DB_CONFIG"
);
f
=
fopen
(
bdb
->
bi_db_config_path
,
"r"
);
if
(
f
)
{
bdb
->
bi_db_has_config
=
1
;
fclose
(
f
);
}
}
break
;
case
BDB_NOSYNC
:
if
(
c
->
value_int
)
bdb
->
bi_dbenv_xflags
|=
DB_TXN_NOSYNC
;
...
...
This diff is collapsed.
Click to expand it.
servers/slapd/back-bdb/init.c
+
28
−
0
View file @
bff244da
...
...
@@ -381,6 +381,29 @@ bdb_db_open( BackendDB *be )
ldap_pvt_thread_mutex_unlock
(
&
slapd_rq
.
rq_mutex
);
}
if
(
slapMode
&
SLAP_SERVER_MODE
&&
bdb
->
bi_db_has_config
)
{
char
buf
[
SLAP_TEXT_BUFLEN
];
FILE
*
f
=
fopen
(
bdb
->
bi_db_config_path
,
"r"
);
struct
berval
bv
;
if
(
f
)
{
while
(
fgets
(
buf
,
sizeof
(
buf
),
f
))
{
ber_str2bv
(
buf
,
0
,
1
,
&
bv
);
if
(
bv
.
bv_val
[
bv
.
bv_len
-
1
]
==
'\n'
)
{
bv
.
bv_len
--
;
bv
.
bv_val
[
bv
.
bv_len
]
=
'\0'
;
}
ber_bvarray_add
(
&
bdb
->
bi_db_config
,
&
bv
);
}
fclose
(
f
);
}
else
{
/* Eh? It disappeared between config and open?? */
bdb
->
bi_db_has_config
=
0
;
}
}
bdb
->
bi_db_is_open
=
1
;
return
0
;
}
...
...
@@ -392,6 +415,10 @@ bdb_db_close( BackendDB *be )
struct
bdb_db_info
*
db
;
bdb_idl_cache_entry_t
*
entry
,
*
next_entry
;
bdb
->
bi_db_is_open
=
0
;
ber_bvarray_free
(
bdb
->
bi_db_config
);
while
(
bdb
->
bi_ndatabases
--
)
{
db
=
bdb
->
bi_databases
[
bdb
->
bi_ndatabases
];
rc
=
db
->
bdi_db
->
close
(
db
->
bdi_db
,
0
);
...
...
@@ -463,6 +490,7 @@ bdb_db_destroy( BackendDB *be )
}
if
(
bdb
->
bi_dbenv_home
)
ch_free
(
bdb
->
bi_dbenv_home
);
if
(
bdb
->
bi_db_config_path
)
ch_free
(
bdb
->
bi_db_config_path
);
ldap_pvt_thread_rdwr_destroy
(
&
bdb
->
bi_cache
.
c_rwlock
);
ldap_pvt_thread_mutex_destroy
(
&
bdb
->
bi_cache
.
lru_mutex
);
...
...
This diff is collapsed.
Click to expand it.
Preview
0%
Loading
Try again
or
attach a new file
.
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Save comment
Cancel
Please
register
or
sign in
to comment