1<!--$Id-->
2<!--Copyright (c) 1997,2008 Oracle.  All rights reserved.-->
3<!--See the file LICENSE for redistribution information.-->
4<html>
5<head>
6<title>Berkeley DB: DB_ENV-&gt;log_set_config</title>
7<meta name="description" content="Berkeley DB: An embedded database programmatic toolkit.">
8<meta name="keywords" content="embedded,database,programmatic,toolkit,btree,hash,hashing,transaction,transactions,locking,logging,access method,access methods,Java,C,C++">
9</head>
10<body bgcolor=white>
11<table width="100%"><tr valign=top>
12<td>
13<b>DB_ENV-&gt;log_set_config</b>
14</td>
15<td align=right>
16<a href="/api_c/api_core.html"><img src="/images/api.gif" alt="API"></a>
17<a href="/ref/toc.html"><img src="/images/ref.gif" alt="Ref"></a></td>
18</tr></table>
19<hr size=1 noshade>
20<tt>
21<b><pre>
22#include &lt;db.h&gt;
23<p>
24int
25DB_ENV-&gt;log_set_config(DB_ENV *dbenv, u_int32_t flags, int onoff);
26<p>
27int
28DB_ENV-&gt;log_get_config(DB_ENV *dbenv, u_int32_t which, int *onoffp);
29</pre></b>
30<hr size=1 noshade>
31<b>Description: DB_ENV-&gt;log_set_config</b>
32<p>The DB_ENV-&gt;log_set_config method configures the Berkeley DB logging
33subsystem.</p>
34<p>The DB_ENV-&gt;log_set_config method configures a database environment, not only operations
35performed using the specified <a href="/api_c/env_class.html">DB_ENV</a> handle.</p>
36<p>The DB_ENV-&gt;log_set_config method may be called at any time during the life of the
37application.</p>
38<p>The DB_ENV-&gt;log_set_config method
39returns a non-zero error value on failure
40and 0 on success.
41</p>
42<b>Parameters</b> <br>
43 <b>flags</b><ul compact><li>The <b>flags</b> parameter must be set by bitwise inclusively <b>OR</b>'ing together one or more
44of the following values:
45<br>
46<a name="2"><!--meow--></a>
47<b><a name="DB_LOG_DIRECT">DB_LOG_DIRECT</a></b><ul compact><li>Turn off system buffering of Berkeley DB log files to avoid double caching.
48<p>Calling DB_ENV-&gt;log_set_config with the DB_LOG_DIRECT flag only affects
49the specified <a href="/api_c/env_class.html">DB_ENV</a> handle (and any other Berkeley DB handles opened
50within the scope of that handle).
51For consistent behavior across the environment, all <a href="/api_c/env_class.html">DB_ENV</a>
52handles opened in the environment must either set the DB_LOG_DIRECT flag
53or the flag should be specified in the <a href="/ref/env/db_config.html#DB_CONFIG">DB_CONFIG</a> configuration
54file.</p>
55<p>The DB_LOG_DIRECT flag may be used to configure Berkeley DB at any time during
56the life of the application.</p></ul>
57<a name="3"><!--meow--></a>
58<b><a name="DB_LOG_DSYNC">DB_LOG_DSYNC</a></b><ul compact><li>Configure Berkeley DB to flush log writes to the backing disk before returning
59from the write system call, rather than flushing log writes explicitly
60in a separate system call, as necessary.  This is only available on some
61systems (for example, systems supporting the IEEE/ANSI Std 1003.1 (POSIX) standard
62O_DSYNC flag, or systems supporting the Windows FILE_FLAG_WRITE_THROUGH
63flag).  This flag may result in inaccurate file modification times and
64other file-level information for Berkeley DB log files.  This flag may offer
65a performance increase on some systems and a performance decrease on
66others.
67<p>Calling DB_ENV-&gt;log_set_config with the DB_LOG_DSYNC flag only affects
68the specified <a href="/api_c/env_class.html">DB_ENV</a> handle (and any other Berkeley DB handles opened
69within the scope of that handle).
70For consistent behavior across the environment, all <a href="/api_c/env_class.html">DB_ENV</a>
71handles opened in the environment must either set the DB_LOG_DSYNC flag
72or the flag should be specified in the <a href="/ref/env/db_config.html#DB_CONFIG">DB_CONFIG</a> configuration
73file.</p>
74<p>The DB_LOG_DSYNC flag may be used to configure Berkeley DB at any time during
75the life of the application.</p></ul>
76<a name="4"><!--meow--></a>
77<b><a name="DB_LOG_AUTO_REMOVE">DB_LOG_AUTO_REMOVE</a></b><ul compact><li>If set, Berkeley DB will automatically remove log files that are no longer
78needed.
79<p>Automatic log file removal is likely to make catastrophic recovery
80impossible.</p>
81<p>Replication applications will rarely want to configure automatic log
82file removal as it increases the likelihood a master will be unable to
83satisfy a client's request for a recent log record.</p>
84<p>Calling DB_ENV-&gt;log_set_config with the DB_LOG_AUTO_REMOVE flag affects the
85database environment, including all threads of control accessing the
86database environment.</p>
87<p>The DB_LOG_AUTO_REMOVE flag may be used to configure Berkeley DB at any time during
88the life of the application.</p></ul>
89<a name="5"><!--meow--></a>
90<b><a name="DB_LOG_IN_MEMORY">DB_LOG_IN_MEMORY</a></b><ul compact><li>If set, maintain transaction logs in memory rather than on disk.  This
91means that transactions exhibit the ACI (atomicity, consistency, and
92isolation) properties, but not D (durability); that is, database
93integrity will be maintained, but if the application or system fails,
94integrity will not persist.  All database files must be verified and/or
95restored from a replication group master or archival backup after
96application or system failure.
97<p>When in-memory logs are configured and no more log buffer space is
98available, Berkeley DB methods may return an additional error value,
99<a name="DB_LOG_BUFFER_FULL">DB_LOG_BUFFER_FULL</a>.  When choosing log buffer and file sizes
100for in-memory logs, applications should ensure the in-memory log buffer
101size is large enough that no transaction will ever span the entire
102buffer, and avoid a state where the in-memory buffer is full and no
103space can be freed because a transaction that started in the first log
104"file" is still active.</p>
105<p>Calling DB_ENV-&gt;log_set_config with the DB_LOG_IN_MEMORY flag affects the
106database environment, including all threads of control accessing the
107database environment.</p>
108<p>The DB_LOG_IN_MEMORY flag may be used to configure Berkeley DB only before the
109<a href="/api_c/env_open.html">DB_ENV-&gt;open</a> method is called.</p></ul>
110<a name="6"><!--meow--></a>
111<b><a name="DB_LOG_ZERO">DB_LOG_ZERO</a></b><ul compact><li>If set, zero all pages of a log file when that log file is created.  This
112has shown to provide greater transaction throughput in some environments.
113The log file will be zeroed by the thread which needs to re-create the new log
114file.  Other threads may not write to the log file while this is happening.
115<p>Calling DB_ENV-&gt;log_set_config with the DB_LOG_ZERO flag affects the
116database environment, including all threads of control accessing the
117database environment.</p>
118<p>The DB_LOG_ZERO flag may be used to configure Berkeley DB only before the
119<a href="/api_c/env_open.html">DB_ENV-&gt;open</a> method is called.</p></ul>
120<br></ul>
121 <b>onoff</b><ul compact><li>If the <b>onoff</b> parameter is zero, the specified flags are cleared;
122otherwise they are set.</ul>
123<br>
124<br><b>Errors</b>
125<p>The DB_ENV-&gt;log_set_config method
126may fail and return one of the following non-zero errors:</p>
127<br>
128<b>EINVAL</b><ul compact><li>An
129invalid flag value or parameter was specified.</ul>
130<br>
131<hr size=1 noshade>
132<b>Description: DB_ENV-&gt;log_get_config</b>
133<p>The DB_ENV-&gt;log_get_config method returns whether the specified <b>which</b>
134parameter is currently set or not.</p>
135<p>The DB_ENV-&gt;log_get_config method may be called at any time during the life of the
136application.</p>
137<p>The DB_ENV-&gt;log_get_config method
138returns a non-zero error value on failure
139and 0 on success.
140</p>
141<b>Parameters</b> <br>
142 <b>which</b><ul compact><li>The <b>which</b> parameter is the message value for which configuration
143is being checked.</ul>
144 <b>onoffp</b><ul compact><li>The <b>onoffp</b> parameter references memory into which
145 the configuration of the specified <b>which</b> parameter is copied.</ul> If the returned <b>onoff</b> value is zero, the parameter is off;
146otherwise on.
147<br>
148<hr size=1 noshade>
149<br><b>Class</b>
150<a href="/api_c/env_class.html">DB_ENV</a>
151<br><b>See Also</b>
152<a href="/api_c/env_list.html">Database Environments and Related Methods</a>
153</tt>
154<table width="100%"><tr><td><br></td><td align=right>
155<a href="/api_c/api_core.html"><img src="/images/api.gif" alt="API"></a><a href="/ref/toc.html"><img src="/images/ref.gif" alt="Ref"></a>
156</td></tr></table>
157<p><font size=1>Copyright (c) 1996,2008 Oracle.  All rights reserved.</font>
158</body>
159</html>
160