From 84fe79c086a4623e1bb1c0ca5cebff19d19d15ec Mon Sep 17 00:00:00 2001 From: Vikas Gorur Date: Thu, 21 Jan 2010 06:46:25 +0000 Subject: storage/posix: Make the janitor sleep duration configurable. Signed-off-by: Vikas Gorur Signed-off-by: Anand V. Avati BUG: 533 (close() should not block main loop) URL: http://bugs.gluster.com/cgi-bin/bugzilla3/show_bug.cgi?id=533 --- xlators/storage/posix/src/posix.c | 45 ++++++++++++++++++++++++++++----------- xlators/storage/posix/src/posix.h | 2 ++ 2 files changed, 35 insertions(+), 12 deletions(-) (limited to 'xlators/storage') diff --git a/xlators/storage/posix/src/posix.c b/xlators/storage/posix/src/posix.c index 64c712bfd..1ff9a06f9 100644 --- a/xlators/storage/posix/src/posix.c +++ b/xlators/storage/posix/src/posix.c @@ -1350,9 +1350,6 @@ janitor_walker (const char *fpath, const struct stat *sb, } -#define JANITOR_SLEEP_DURATION 600 - - static struct posix_fd * janitor_get_next_fd (xlator_t *this) { @@ -1367,7 +1364,7 @@ janitor_get_next_fd (xlator_t *this) { if (list_empty (&priv->janitor_fds)) { time (&timeout.tv_sec); - timeout.tv_sec += JANITOR_SLEEP_DURATION; + timeout.tv_sec += priv->janitor_sleep_duration; timeout.tv_nsec = 0; pthread_cond_timedwait (&priv->janitor_cond, @@ -1395,19 +1392,26 @@ posix_janitor_thread_proc (void *data) struct posix_private *priv = NULL; struct posix_fd *pfd; + time_t now; + this = data; priv = this->private; THIS = this; while (1) { - gf_log (this->name, GF_LOG_TRACE, - "janitor woke up, cleaning out /" GF_REPLICATE_TRASH_DIR); + time (&now); + if ((now - priv->last_landfill_check) > priv->janitor_sleep_duration) { + gf_log (this->name, GF_LOG_TRACE, + "janitor cleaning out /" GF_REPLICATE_TRASH_DIR); - nftw (priv->trash_path, - janitor_walker, - 32, - FTW_DEPTH | FTW_PHYS); + nftw (priv->trash_path, + janitor_walker, + 32, + FTW_DEPTH | FTW_PHYS); + + priv->last_landfill_check = now; + } pfd = janitor_get_next_fd (this); if (pfd) { @@ -4806,6 +4810,9 @@ init (xlator_t *this) data_t * tmp_data = NULL; uint64_t time64 = 0; + int dict_ret = 0; + int32_t janitor_sleep; + dir_data = dict_get (this->options, "directory"); if (this->children) { @@ -4986,10 +4993,22 @@ init (xlator_t *this) } _private->st_device = CALLOC (1, (sizeof (dev_t) * _private->num_devices_to_span)); - + /* Start with the base */ _private->st_device[0] = buf.st_dev; + _private->janitor_sleep_duration = 600; + + dict_ret = dict_get_int32 (this->options, "janitor-sleep-duration", + &janitor_sleep); + if (dict_ret == 0) { + gf_log (this->name, GF_LOG_DEBUG, + "Setting janitor sleep duration to %d.", + janitor_sleep); + + _private->janitor_sleep_duration = janitor_sleep; + } + LOCK_INIT (&_private->gen_lock); time64 = time (NULL); _private->gen_seq = (time64 << 32); @@ -5114,6 +5133,8 @@ struct volume_options options[] = { { .key = {"span-devices"}, .type = GF_OPTION_TYPE_INT }, { .key = {"background-unlink"}, - .type = GF_OPTION_TYPE_BOOL }, + .type = GF_OPTION_TYPE_BOOL }, + { .key = {"janitor-sleep-duration"}, + .type = GF_OPTION_TYPE_INT }, { .key = {NULL} } }; diff --git a/xlators/storage/posix/src/posix.h b/xlators/storage/posix/src/posix.h index 3280c979e..f92e256fb 100644 --- a/xlators/storage/posix/src/posix.h +++ b/xlators/storage/posix/src/posix.h @@ -78,6 +78,8 @@ struct posix_private { struct timeval prev_fetch_time; struct timeval init_time; + time_t last_landfill_check; + int32_t janitor_sleep_duration; struct list_head janitor_fds; pthread_cond_t janitor_cond; pthread_mutex_t janitor_lock; -- cgit