summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rambler-co.ru>2011-11-01 20:48:30 +0300
committerVsevolod Stakhov <vsevolod@rambler-co.ru>2011-11-01 20:48:30 +0300
commit323cc58a8819d8356562bbc2de55d4ef920b22cc (patch)
treef66b05e5f9f813f279bca705e4bb95f4951a6c66
parent7770c0c2ff70150fe33358a461fadf91e01ae23f (diff)
downloadrspamd-323cc58a8819d8356562bbc2de55d4ef920b22cc.tar.gz
rspamd-323cc58a8819d8356562bbc2de55d4ef920b22cc.zip
Fixes to BDB initialization.
-rw-r--r--src/kvstorage.h3
-rw-r--r--src/kvstorage_bdb.c50
-rw-r--r--src/kvstorage_config.c9
-rw-r--r--src/kvstorage_config.h2
-rw-r--r--src/kvstorage_server.c1
5 files changed, 46 insertions, 19 deletions
diff --git a/src/kvstorage.h b/src/kvstorage.h
index 00ff20e9a..d13e93079 100644
--- a/src/kvstorage.h
+++ b/src/kvstorage.h
@@ -122,7 +122,8 @@ struct rspamd_kv_storage {
/** Create new kv storage */
struct rspamd_kv_storage *rspamd_kv_storage_new (gint id, const gchar *name,
- struct rspamd_kv_cache *cache, struct rspamd_kv_backend *backend, struct rspamd_kv_expire *expire,
+ struct rspamd_kv_cache *cache, struct rspamd_kv_backend *backend,
+ struct rspamd_kv_expire *expire,
gsize max_elts, gsize max_memory);
/** Insert new element to the kv storage */
diff --git a/src/kvstorage_bdb.c b/src/kvstorage_bdb.c
index 4524cb7bc..fb1a34a83 100644
--- a/src/kvstorage_bdb.c
+++ b/src/kvstorage_bdb.c
@@ -26,6 +26,7 @@
#include "kvstorage.h"
#include "kvstorage_bdb.h"
#include "util.h"
+#include "main.h"
#include <db.h>
struct bdb_op {
@@ -65,20 +66,21 @@ bdb_process_single_op (struct rspamd_bdb_backend *db, DB_TXN *txn, DBC *cursorp,
memset (&db_data, 0, sizeof(DBT));
db_key.size = strlen (op->elt->key);
db_key.data = op->elt->key;
- db_data.size = op->elt->size;
+ db_data.size = op->elt->size + sizeof (struct rspamd_kv_element);
db_data.data = op->elt;
switch (op->op) {
case BDB_OP_INSERT:
case BDB_OP_REPLACE:
- if (cursorp->put (cursorp, &db_key, &db_data, 0) != 0) {
+ db_data.flags = DB_DBT_USERMEM;
+ if (cursorp->put (cursorp, &db_key, &db_data, DB_KEYFIRST) != 0) {
return FALSE;
}
break;
case BDB_OP_DELETE:
db_data.flags = DB_DBT_USERMEM;
/* Set cursor */
- if (cursorp->get (cursorp, &db_key, &db_data, 0) != 0) {
+ if (cursorp->get (cursorp, &db_key, &db_data, DB_SET) != 0) {
return FALSE;
}
/* Del record */
@@ -88,6 +90,7 @@ bdb_process_single_op (struct rspamd_bdb_backend *db, DB_TXN *txn, DBC *cursorp,
break;
}
+ op->elt->flags &= ~KV_ELT_DIRTY;
return TRUE;
}
@@ -133,7 +136,7 @@ bdb_process_queue (struct rspamd_bdb_backend *db)
g_hash_table_remove (db->ops_hash, op->elt->key);
if (op->op == BDB_OP_DELETE) {
/* Also clean memory */
- g_free (op->elt);
+ g_slice_free1 (sizeof (struct rspamd_kv_element) + op->elt->size, op->elt);
}
cur = g_list_next (cur);
g_queue_delete_link (db->ops_queue, tmp);
@@ -150,18 +153,22 @@ rspamd_bdb_init (struct rspamd_kv_backend *backend)
{
struct rspamd_bdb_backend *db = (struct rspamd_bdb_backend *)backend;
guint32 flags;
+ gint ret;
- if (db_env_create (&db->envp, 0) != 0) {
+ if ((ret = db_env_create (&db->envp, 0)) != 0) {
/* Cannot create environment */
goto err;
}
- flags = DB_CREATE | /* Create the environment if it does not already exist. */
- DB_INIT_TXN | /* Initialize transactions */
- DB_INIT_LOCK | /* Initialize locking. */
- DB_THREAD; /* Use threads */
+ flags = DB_INIT_MPOOL |
+ DB_RECOVER |
+ DB_CREATE | /* Create the environment if it does not already exist. */
+ DB_INIT_TXN | /* Initialize transactions */
+ DB_INIT_LOCK | /* Initialize locking. */
+ DB_INIT_LOG | /* Initialize logging */
+ DB_THREAD; /* Use threads */
- if (db->envp->open (db->envp, db->dirname, flags, 0) != 0) {
+ if ((ret = db->envp->open (db->envp, db->dirname, flags, 0)) != 0) {
/* Cannot open environment */
goto err;
}
@@ -172,13 +179,13 @@ rspamd_bdb_init (struct rspamd_kv_backend *backend)
*/
db->envp->set_lk_detect(db->envp, DB_LOCK_MINWRITE);
- flags = DB_CREATE | DB_THREAD;
+ flags = DB_CREATE | DB_THREAD | DB_AUTO_COMMIT;
/* Create and open db pointer */
- if (db_create (&db->dbp, db->envp, 0) != 0) {
+ if ((ret = db_create (&db->dbp, db->envp, 0)) != 0) {
goto err;
}
- if (db->dbp->open (db->dbp, NULL, db->filename, NULL, DB_BTREE, flags, 0) != 0) {
+ if ((ret = db->dbp->open (db->dbp, NULL, db->filename, NULL, DB_BTREE, flags, 0)) != 0) {
goto err;
}
@@ -187,9 +194,11 @@ rspamd_bdb_init (struct rspamd_kv_backend *backend)
return;
err:
if (db->dbp != NULL) {
+ msg_err ("error opening bdb database: %s", db_strerror (ret));
db->dbp->close (db->dbp, 0);
}
if (db->envp != NULL) {
+ msg_err ("error opening bdb environment: %s", db_strerror (ret));
db->envp->close (db->envp, 0);
}
}
@@ -209,8 +218,8 @@ rspamd_bdb_insert (struct rspamd_kv_backend *backend, gpointer key, struct rspam
op->elt = elt;
elt->flags |= KV_ELT_DIRTY;
- g_queue_push_head (db->ops_queue, elt);
- g_hash_table_insert (db->ops_hash, key, elt);
+ g_queue_push_head (db->ops_queue, op);
+ g_hash_table_insert (db->ops_hash, key, op);
if (g_queue_get_length (db->ops_queue) >= db->sync_ops) {
return bdb_process_queue (db);
@@ -234,8 +243,8 @@ rspamd_bdb_replace (struct rspamd_kv_backend *backend, gpointer key, struct rspa
op->elt = elt;
elt->flags |= KV_ELT_DIRTY;
- g_queue_push_head (db->ops_queue, elt);
- g_hash_table_insert (db->ops_hash, key, elt);
+ g_queue_push_head (db->ops_queue, op);
+ g_hash_table_insert (db->ops_hash, key, op);
if (g_queue_get_length (db->ops_queue) >= db->sync_ops) {
return bdb_process_queue (db);
@@ -275,8 +284,10 @@ rspamd_bdb_lookup (struct rspamd_kv_backend *backend, gpointer key)
db_key.data = key;
db_data.flags = DB_DBT_MALLOC;
- if (cursorp->get (cursorp, &db_key, &db_data, 0) == 0) {
+ if (cursorp->get (cursorp, &db_key, &db_data, DB_SET) == 0) {
elt = db_data.data;
+ elt->key = key;
+ elt->flags &= ~KV_ELT_DIRTY;
}
cursorp->close (cursorp);
@@ -295,6 +306,7 @@ rspamd_bdb_delete (struct rspamd_kv_backend *backend, gpointer key)
}
if ((op = g_hash_table_lookup (db->ops_hash, key)) != NULL) {
+ op->op = BDB_OP_DELETE;
return;
}
@@ -323,6 +335,7 @@ rspamd_bdb_destroy (struct rspamd_kv_backend *backend)
struct rspamd_bdb_backend *db = (struct rspamd_bdb_backend *)backend;
if (db->initialized) {
+ bdb_process_queue (db);
if (db->dbp != NULL) {
db->dbp->close (db->dbp, 0);
}
@@ -354,6 +367,7 @@ rspamd_kv_bdb_new (const gchar *filename, guint sync_ops)
if (dirname != NULL) {
g_free (dirname);
}
+ msg_err ("invalid file: %s", filename);
return NULL;
}
diff --git a/src/kvstorage_config.c b/src/kvstorage_config.c
index 2bf905cae..0dbad5380 100644
--- a/src/kvstorage_config.c
+++ b/src/kvstorage_config.c
@@ -465,3 +465,12 @@ get_kvstorage_config (gint id)
}
return g_hash_table_lookup (storages, &id);
}
+
+void
+destroy_kvstorage_config (void)
+{
+ if (storages != NULL) {
+ g_hash_table_destroy (storages);
+ storages = NULL;
+ }
+}
diff --git a/src/kvstorage_config.h b/src/kvstorage_config.h
index ced149c4e..b6f980b94 100644
--- a/src/kvstorage_config.h
+++ b/src/kvstorage_config.h
@@ -83,4 +83,6 @@ void init_kvstorage_config (void);
/* Get configuration for kvstorage with specified ID */
struct kvstorage_config* get_kvstorage_config (gint id);
+void destroy_kvstorage_config (void);
+
#endif /* KVSTORAGE_CONFIG_H_ */
diff --git a/src/kvstorage_server.c b/src/kvstorage_server.c
index d3bfd8ff6..afdc8b163 100644
--- a/src/kvstorage_server.c
+++ b/src/kvstorage_server.c
@@ -616,6 +616,7 @@ start_kvstorage_worker (struct rspamd_worker *worker)
}
}
+ destroy_kvstorage_config ();
close_log (rspamd_main->logger);
exit (EXIT_SUCCESS);
}