First public contribution.
4 ** The author disclaims copyright to this source code. In place of
5 ** a legal notice, here is a blessing:
7 ** May you do good and not evil.
8 ** May you find forgiveness for yourself and forgive others.
9 ** May you share freely, never taking more than you give.
11 ******************************************************************************
13 ** $Id: test_server.c,v 1.8 2008/06/26 10:41:19 danielk1977 Exp $
15 ** This file contains demonstration code. Nothing in this file gets compiled
16 ** or linked into the SQLite library unless you use a non-standard option:
20 ** The configure script will never generate a Makefile with the option
21 ** above. You will need to manually modify the Makefile if you want to
22 ** include any of the code from this file in your project. Or, at your
23 ** option, you may copy and paste the code from this file and
24 ** thereby avoiding a recompile of SQLite.
27 ** This source file demonstrates how to use SQLite to create an SQL database
28 ** server thread in a multiple-threaded program. One or more client threads
29 ** send messages to the server thread and the server thread processes those
30 ** messages in the order received and returns the results to the client.
32 ** One might ask: "Why bother? Why not just let each thread connect
33 ** to the database directly?" There are a several of reasons to
34 ** prefer the client/server approach.
36 ** (1) Some systems (ex: Redhat9) have broken threading implementations
37 ** that prevent SQLite database connections from being used in
38 ** a thread different from the one where they were created. With
39 ** the client/server approach, all database connections are created
40 ** and used within the server thread. Client calls to the database
41 ** can be made from multiple threads (though not at the same time!)
43 ** (2) Beginning with SQLite version 3.3.0, when two or more
44 ** connections to the same database occur within the same thread,
45 ** they can optionally share their database cache. This reduces
46 ** I/O and memory requirements. Cache shared is controlled using
47 ** the sqlite3_enable_shared_cache() API.
49 ** (3) Database connections on a shared cache use table-level locking
50 ** instead of file-level locking for improved concurrency.
52 ** (4) Database connections on a shared cache can by optionally
53 ** set to READ UNCOMMITTED isolation. (The default isolation for
54 ** SQLite is SERIALIZABLE.) When this occurs, readers will
55 ** never be blocked by a writer and writers will not be
56 ** blocked by readers. There can still only be a single writer
57 ** at a time, but multiple readers can simultaneously exist with
58 ** that writer. This is a huge increase in concurrency.
60 ** To summarize the rational for using a client/server approach: prior
61 ** to SQLite version 3.3.0 it probably was not worth the trouble. But
62 ** with SQLite version 3.3.0 and beyond you can get significant performance
63 ** and concurrency improvements and memory usage reductions by going
66 ** Note: The extra features of version 3.3.0 described by points (2)
67 ** through (4) above are only available if you compile without the
68 ** option -DSQLITE_OMIT_SHARED_CACHE.
70 ** Here is how the client/server approach works: The database server
71 ** thread is started on this procedure:
73 ** void *sqlite3_server(void *NotUsed);
75 ** The sqlite_server procedure runs as long as the g.serverHalt variable
76 ** is false. A mutex is used to make sure no more than one server runs
77 ** at a time. The server waits for messages to arrive on a message
78 ** queue and processes the messages in order.
80 ** Two convenience routines are provided for starting and stopping the
83 ** void sqlite3_server_start(void);
84 ** void sqlite3_server_stop(void);
86 ** Both of the convenience routines return immediately. Neither will
87 ** ever give an error. If a server is already started or already halted,
88 ** then the routines are effectively no-ops.
90 ** Clients use the following interfaces:
92 ** sqlite3_client_open
93 ** sqlite3_client_prepare
94 ** sqlite3_client_step
95 ** sqlite3_client_reset
96 ** sqlite3_client_finalize
97 ** sqlite3_client_close
99 ** These interfaces work exactly like the standard core SQLite interfaces
100 ** having the same names without the "_client_" infix. Many other SQLite
101 ** interfaces can be used directly without having to send messages to the
102 ** server as long as SQLITE_ENABLE_MEMORY_MANAGEMENT is not defined.
103 ** The following interfaces fall into this second category:
107 ** sqlite3_clear_bindings
110 ** sqlite3_create_collation
111 ** sqlite3_create_function
112 ** sqlite3_data_count
116 ** sqlite3_last_insert_rowid
117 ** sqlite3_total_changes
118 ** sqlite3_transfer_bindings
120 ** A single SQLite connection (an sqlite3* object) or an SQLite statement
121 ** (an sqlite3_stmt* object) should only be passed to a single interface
122 ** function at a time. The connections and statements can be passed from
123 ** any thread to any of the functions listed in the second group above as
124 ** long as the same connection is not in use by two threads at once and
125 ** as long as SQLITE_ENABLE_MEMORY_MANAGEMENT is not defined. Additional
126 ** information about the SQLITE_ENABLE_MEMORY_MANAGEMENT constraint is
129 ** The busy handler for all database connections should remain turned
130 ** off. That means that any lock contention will cause the associated
131 ** sqlite3_client_step() call to return immediately with an SQLITE_BUSY
132 ** error code. If a busy handler is enabled and lock contention occurs,
133 ** then the entire server thread will block. This will cause not only
134 ** the requesting client to block but every other database client as
135 ** well. It is possible to enhance the code below so that lock
136 ** contention will cause the message to be placed back on the top of
137 ** the queue to be tried again later. But such enhanced processing is
138 ** not included here, in order to keep the example simple.
140 ** This example code assumes the use of pthreads. Pthreads
141 ** implementations are available for windows. (See, for example
142 ** http://sourceware.org/pthreads-win32/announcement.html.) Or, you
143 ** can translate the locking and thread synchronization code to use
144 ** windows primitives easily enough. The details are left as an
145 ** exercise to the reader.
147 **** Restrictions Associated With SQLITE_ENABLE_MEMORY_MANAGEMENT ****
149 ** If you compile with SQLITE_ENABLE_MEMORY_MANAGEMENT defined, then
150 ** SQLite includes code that tracks how much memory is being used by
151 ** each thread. These memory counts can become confused if memory
152 ** is allocated by one thread and then freed by another. For that
153 ** reason, when SQLITE_ENABLE_MEMORY_MANAGEMENT is used, all operations
154 ** that might allocate or free memory should be performanced in the same
155 ** thread that originally created the database connection. In that case,
156 ** many of the operations that are listed above as safe to be performed
157 ** in separate threads would need to be sent over to the server to be
158 ** done there. If SQLITE_ENABLE_MEMORY_MANAGEMENT is defined, then
159 ** the following functions can be used safely from different threads
160 ** without messing up the allocation counts:
162 ** sqlite3_bind_parameter_name
163 ** sqlite3_bind_parameter_index
165 ** sqlite3_column_blob
166 ** sqlite3_column_count
168 ** sqlite3_data_count
172 ** sqlite3_last_insert_rowid
173 ** sqlite3_total_changes
175 ** The remaining functions are not thread-safe when memory management
176 ** is enabled. So one would have to define some new interface routines
177 ** along the following lines:
179 ** sqlite3_client_bind_*
180 ** sqlite3_client_clear_bindings
181 ** sqlite3_client_column_*
182 ** sqlite3_client_create_collation
183 ** sqlite3_client_create_function
184 ** sqlite3_client_transfer_bindings
186 ** The example code in this file is intended for use with memory
187 ** management turned off. So the implementation of these additional
188 ** client interfaces is left as an exercise to the reader.
190 ** It may seem surprising to the reader that the list of safe functions
191 ** above does not include things like sqlite3_bind_int() or
192 ** sqlite3_column_int(). But those routines might, in fact, allocate
193 ** or deallocate memory. In the case of sqlite3_bind_int(), if the
194 ** parameter was previously bound to a string that string might need
195 ** to be deallocated before the new integer value is inserted. In
196 ** the case of sqlite3_column_int(), the value of the column might be
197 ** a UTF-16 string which will need to be converted to UTF-8 then into
201 /* Include this to get the definition of SQLITE_THREADSAFE, in the
202 ** case that default values are used.
204 #include "sqliteInt.h"
207 ** Only compile the code in this file on UNIX with a SQLITE_THREADSAFE build
208 ** and only if the SQLITE_SERVER macro is defined.
210 #if defined(SQLITE_SERVER) && !defined(SQLITE_OMIT_SHARED_CACHE)
211 #if defined(SQLITE_OS_UNIX) && OS_UNIX && SQLITE_THREADSAFE
214 ** We require only pthreads and the public interface of SQLite.
220 ** Messages are passed from client to server and back again as
221 ** instances of the following structure.
223 typedef struct SqlMessage SqlMessage;
225 int op; /* Opcode for the message */
226 sqlite3 *pDb; /* The SQLite connection */
227 sqlite3_stmt *pStmt; /* A specific statement */
228 int errCode; /* Error code returned */
229 const char *zIn; /* Input filename or SQL statement */
230 int nByte; /* Size of the zIn parameter for prepare() */
231 const char *zOut; /* Tail of the SQL statement */
232 SqlMessage *pNext; /* Next message in the queue */
233 SqlMessage *pPrev; /* Previous message in the queue */
234 pthread_mutex_t clientMutex; /* Hold this mutex to access the message */
235 pthread_cond_t clientWakeup; /* Signal to wake up the client */
239 ** Legal values for SqlMessage.op
241 #define MSG_Open 1 /* sqlite3_open(zIn, &pDb) */
242 #define MSG_Prepare 2 /* sqlite3_prepare(pDb, zIn, nByte, &pStmt, &zOut) */
243 #define MSG_Step 3 /* sqlite3_step(pStmt) */
244 #define MSG_Reset 4 /* sqlite3_reset(pStmt) */
245 #define MSG_Finalize 5 /* sqlite3_finalize(pStmt) */
246 #define MSG_Close 6 /* sqlite3_close(pDb) */
247 #define MSG_Done 7 /* Server has finished with this message */
251 ** State information about the server is stored in a static variable
252 ** named "g" as follows:
254 static struct ServerState {
255 pthread_mutex_t queueMutex; /* Hold this mutex to access the msg queue */
256 pthread_mutex_t serverMutex; /* Held by the server while it is running */
257 pthread_cond_t serverWakeup; /* Signal this condvar to wake up the server */
258 volatile int serverHalt; /* Server halts itself when true */
259 SqlMessage *pQueueHead; /* Head of the message queue */
260 SqlMessage *pQueueTail; /* Tail of the message queue */
262 PTHREAD_MUTEX_INITIALIZER,
263 PTHREAD_MUTEX_INITIALIZER,
264 PTHREAD_COND_INITIALIZER,
268 ** Send a message to the server. Block until we get a reply.
270 ** The mutex and condition variable in the message are uninitialized
271 ** when this routine is called. This routine takes care of
272 ** initializing them and destroying them when it has finished.
274 static void sendToServer(SqlMessage *pMsg){
275 /* Initialize the mutex and condition variable on the message
277 pthread_mutex_init(&pMsg->clientMutex, 0);
278 pthread_cond_init(&pMsg->clientWakeup, 0);
280 /* Add the message to the head of the server's message queue.
282 pthread_mutex_lock(&g.queueMutex);
283 pMsg->pNext = g.pQueueHead;
284 if( g.pQueueHead==0 ){
287 g.pQueueHead->pPrev = pMsg;
291 pthread_mutex_unlock(&g.queueMutex);
293 /* Signal the server that the new message has be queued, then
294 ** block waiting for the server to process the message.
296 pthread_mutex_lock(&pMsg->clientMutex);
297 pthread_cond_signal(&g.serverWakeup);
298 while( pMsg->op!=MSG_Done ){
299 pthread_cond_wait(&pMsg->clientWakeup, &pMsg->clientMutex);
301 pthread_mutex_unlock(&pMsg->clientMutex);
303 /* Destroy the mutex and condition variable of the message.
305 pthread_mutex_destroy(&pMsg->clientMutex);
306 pthread_cond_destroy(&pMsg->clientWakeup);
310 ** The following 6 routines are client-side implementations of the
311 ** core SQLite interfaces:
320 ** Clients should use the following client-side routines instead of
321 ** the core routines above.
323 ** sqlite3_client_open
324 ** sqlite3_client_prepare
325 ** sqlite3_client_step
326 ** sqlite3_client_reset
327 ** sqlite3_client_finalize
328 ** sqlite3_client_close
330 ** Each of these routines creates a message for the desired operation,
331 ** sends that message to the server, waits for the server to process
332 ** then message and return a response.
334 int sqlite3_client_open(const char *zDatabaseName, sqlite3 **ppDb){
337 msg.zIn = zDatabaseName;
342 int sqlite3_client_prepare(
346 sqlite3_stmt **ppStmt,
350 msg.op = MSG_Prepare;
356 if( pzTail ) *pzTail = msg.zOut;
359 int sqlite3_client_step(sqlite3_stmt *pStmt){
366 int sqlite3_client_reset(sqlite3_stmt *pStmt){
373 int sqlite3_client_finalize(sqlite3_stmt *pStmt){
375 msg.op = MSG_Finalize;
380 int sqlite3_client_close(sqlite3 *pDb){
389 ** This routine implements the server. To start the server, first
390 ** make sure g.serverHalt is false, then create a new detached thread
391 ** on this procedure. See the sqlite3_server_start() routine below
392 ** for an example. This procedure loops until g.serverHalt becomes
395 void *sqlite3_server(void *NotUsed){
396 if( pthread_mutex_trylock(&g.serverMutex) ){
397 return 0; /* Another server is already running */
399 sqlite3_enable_shared_cache(1);
400 while( !g.serverHalt ){
403 /* Remove the last message from the message queue.
405 pthread_mutex_lock(&g.queueMutex);
406 while( g.pQueueTail==0 && g.serverHalt==0 ){
407 pthread_cond_wait(&g.serverWakeup, &g.queueMutex);
412 pMsg->pPrev->pNext = 0;
416 g.pQueueTail = pMsg->pPrev;
418 pthread_mutex_unlock(&g.queueMutex);
421 /* Process the message just removed
423 pthread_mutex_lock(&pMsg->clientMutex);
426 pMsg->errCode = sqlite3_open(pMsg->zIn, &pMsg->pDb);
430 pMsg->errCode = sqlite3_prepare(pMsg->pDb, pMsg->zIn, pMsg->nByte,
431 &pMsg->pStmt, &pMsg->zOut);
435 pMsg->errCode = sqlite3_step(pMsg->pStmt);
439 pMsg->errCode = sqlite3_reset(pMsg->pStmt);
443 pMsg->errCode = sqlite3_finalize(pMsg->pStmt);
447 pMsg->errCode = sqlite3_close(pMsg->pDb);
452 /* Signal the client that the message has been processed.
455 pthread_mutex_unlock(&pMsg->clientMutex);
456 pthread_cond_signal(&pMsg->clientWakeup);
458 sqlite3_thread_cleanup();
459 pthread_mutex_unlock(&g.serverMutex);
464 ** Start a server thread if one is not already running. If there
465 ** is aleady a server thread running, the new thread will quickly
466 ** die and this routine is effectively a no-op.
468 void sqlite3_server_start(void){
472 rc = pthread_create(&x, 0, sqlite3_server, 0);
479 ** If a server thread is running, then stop it. If no server is
480 ** running, this routine is effectively a no-op.
482 ** This routine waits until the server has actually stopped before
485 void sqlite3_server_stop(void){
487 pthread_cond_broadcast(&g.serverWakeup);
488 pthread_mutex_lock(&g.serverMutex);
489 pthread_mutex_unlock(&g.serverMutex);
492 #endif /* defined(SQLITE_OS_UNIX) && OS_UNIX && SQLITE_THREADSAFE */
493 #endif /* defined(SQLITE_SERVER) */