diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-06-26 16:36:36 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-06-26 16:37:06 +0100 |
commit | 3efd7b744da68245805f0da64661ec5cf7cd5483 (patch) | |
tree | 7f9b29571693b6218807fa7db3302a8986ad9ab7 /src/libutil | |
parent | f16ae1bbd43346b8fb2d79b0fd476c771b32a7cc (diff) | |
download | rspamd-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.c | 73 | ||||
-rw-r--r-- | src/libutil/map.h | 6 |
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); |