aboutsummaryrefslogtreecommitdiffstats
path: root/src/libutil
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2018-06-26 16:36:36 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2018-06-26 16:37:06 +0100
commit3efd7b744da68245805f0da64661ec5cf7cd5483 (patch)
tree7f9b29571693b6218807fa7db3302a8986ad9ab7 /src/libutil
parentf16ae1bbd43346b8fb2d79b0fd476c771b32a7cc (diff)
downloadrspamd-3efd7b744da68245805f0da64661ec5cf7cd5483.tar.gz
rspamd-3efd7b744da68245805f0da64661ec5cf7cd5483.zip
[Feature] Preload file and static maps in main process
Diffstat (limited to 'src/libutil')
-rw-r--r--src/libutil/map.c73
-rw-r--r--src/libutil/map.h6
2 files changed, 78 insertions, 1 deletions
diff --git a/src/libutil/map.c b/src/libutil/map.c
index 7a4d48598..8f36541a2 100644
--- a/src/libutil/map.c
+++ b/src/libutil/map.c
@@ -846,7 +846,8 @@ read_map_file (struct rspamd_map *map, struct file_map_data *data,
return FALSE;
}
else {
- msg_info_map ("%s: map file is not found",
+ msg_info_map ("%s: map file is not found; "
+ "it will be read automatically if created",
data->filename);
return TRUE;
}
@@ -1004,6 +1005,9 @@ read_map_file (struct rspamd_map *map, struct file_map_data *data,
map->read_callback (NULL, 0, &periodic->cbdata, TRUE);
}
+ /* Also update at the read time */
+ memcpy (&data->st, &st, sizeof (struct stat));
+
return TRUE;
}
@@ -1730,6 +1734,73 @@ rspamd_map_watch (struct rspamd_config *cfg,
}
void
+rspamd_map_preload (struct rspamd_config *cfg)
+{
+ GList *cur = cfg->maps;
+ struct rspamd_map *map;
+ struct rspamd_map_backend *bk;
+ guint i;
+ gboolean map_ok;
+
+ /* First of all do synced read of data */
+ while (cur) {
+ map = cur->data;
+ map_ok = TRUE;
+
+ PTR_ARRAY_FOREACH (map->backends, i, bk) {
+ if (!(bk->protocol == MAP_PROTO_FILE ||
+ bk->protocol == MAP_PROTO_STATIC)) {
+ map_ok = FALSE;
+ break;
+ }
+ }
+
+ if (map_ok) {
+ struct map_periodic_cbdata fake_cbd;
+ gboolean succeed = TRUE;
+
+ memset (&fake_cbd, 0, sizeof (fake_cbd));
+
+ PTR_ARRAY_FOREACH (map->backends, i, bk) {
+ fake_cbd.cbdata.state = 0;
+ fake_cbd.cbdata.prev_data = *map->user_data;
+ fake_cbd.cbdata.cur_data = NULL;
+ fake_cbd.cbdata.map = map;
+ fake_cbd.map = map;
+ fake_cbd.cur_backend = i;
+
+ if (bk->protocol == MAP_PROTO_FILE) {
+ if (!read_map_file (map, bk->data.fd, bk, &fake_cbd)) {
+ succeed = FALSE;
+ break;
+ }
+ }
+ else if (bk->protocol == MAP_PROTO_STATIC) {
+ if (!read_map_static (map, bk->data.sd, bk, &fake_cbd)) {
+ succeed = FALSE;
+ break;
+ }
+ }
+ else {
+ g_assert_not_reached ();
+ }
+ }
+
+ if (succeed) {
+ map->fin_callback (&fake_cbd.cbdata);
+
+ if (fake_cbd.cbdata.cur_data) {
+ *map->user_data = fake_cbd.cbdata.cur_data;
+ }
+ }
+
+ }
+
+ cur = g_list_next (cur);
+ }
+}
+
+void
rspamd_map_remove_all (struct rspamd_config *cfg)
{
struct rspamd_map *map;
diff --git a/src/libutil/map.h b/src/libutil/map.h
index 9c7485c58..80aa03825 100644
--- a/src/libutil/map.h
+++ b/src/libutil/map.h
@@ -85,6 +85,12 @@ void rspamd_map_watch (struct rspamd_config *cfg,
gboolean active_http);
/**
+ * Preloads maps where all backends are file
+ * @param cfg
+ */
+void rspamd_map_preload (struct rspamd_config *cfg);
+
+/**
* Remove all maps watched (remove events)
*/
void rspamd_map_remove_all (struct rspamd_config *cfg);