diff options
author | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2010-09-16 19:18:23 +0400 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2010-09-16 19:18:23 +0400 |
commit | 18e0c770b951c5d8a1269b3829b73a416fc261fe (patch) | |
tree | 31ab1e9eee734251a883b0e9409f7983fedd940d /src/statfile.c | |
parent | e2d78f30503d3f02eec9925f2e222b7b1493f1ad (diff) | |
download | rspamd-18e0c770b951c5d8a1269b3829b73a416fc261fe.tar.gz rspamd-18e0c770b951c5d8a1269b3829b73a416fc261fe.zip |
* Fix shared usage of statfiles
* Add invalidation of statfiles in case of learning, so now statfiles
are invalidated in about a minute after learning
* This should fix shared usage of statfile pool by several processes
Diffstat (limited to 'src/statfile.c')
-rw-r--r-- | src/statfile.c | 39 |
1 files changed, 36 insertions, 3 deletions
diff --git a/src/statfile.c b/src/statfile.c index 0460a43c8..1660a29f4 100644 --- a/src/statfile.c +++ b/src/statfile.c @@ -209,11 +209,10 @@ statfile_pool_new (memory_pool_t *pool, size_t max_size) { statfile_pool_t *new; - new = memory_pool_alloc_shared (pool, sizeof (statfile_pool_t)); - bzero (new, sizeof (statfile_pool_t)); + new = memory_pool_alloc0 (pool, sizeof (statfile_pool_t)); new->pool = memory_pool_new (memory_pool_get_size ()); new->max = max_size; - new->files = memory_pool_alloc_shared (new->pool, STATFILES_MAX * sizeof (stat_file_t)); + new->files = memory_pool_alloc0 (new->pool, STATFILES_MAX * sizeof (stat_file_t)); new->lock = memory_pool_get_mutex (new->pool); return new; @@ -813,3 +812,37 @@ statfile_get_total_blocks (stat_file_t *file) return header->total_blocks; } + +static void +statfile_pool_invalidate_callback (int fd, short what, void *ud) +{ + statfile_pool_t *pool = ud; + stat_file_t *file; + int i; + + msg_info ("invalidating %d statfiles", pool->opened); + + for (i = 0; i < pool->opened; i ++) { + file = &pool->files[i]; + msync (file->map, file->len, MS_ASYNC | MS_INVALIDATE); + } + +} + + +void +statfile_pool_plan_invalidate (statfile_pool_t *pool, time_t seconds, time_t jitter) +{ + + if (pool->invalidate_event == NULL || ! evtimer_pending (pool->invalidate_event, NULL)) { + + if (pool->invalidate_event == NULL) { + pool->invalidate_event = memory_pool_alloc (pool->pool, sizeof (struct event)); + } + pool->invalidate_tv.tv_sec = seconds + g_random_int_range (0, jitter); + pool->invalidate_tv.tv_usec = 0; + evtimer_set (pool->invalidate_event, statfile_pool_invalidate_callback, pool); + evtimer_add (pool->invalidate_event, &pool->invalidate_tv); + msg_info ("invalidate of statfile pool is planned in %d seconds", (int)pool->invalidate_tv.tv_sec); + } +} |