X-Git-Url: https://git.saurik.com/redis.git/blobdiff_plain/4f948300bc26abb0aaa99343bc9f089ea98a9abe..591f29e0f5493f1e375c06ae225dc5aafe5b37fb:/src/redis.c?ds=sidebyside diff --git a/src/redis.c b/src/redis.c index dbc800fd..e7351b6e 100644 --- a/src/redis.c +++ b/src/redis.c @@ -692,14 +692,16 @@ int serverCron(struct aeEventLoop *eventLoop, long long id, void *clientData) { } /* Trigger an AOF rewrite if needed */ - if (server.auto_aofrewrite_perc && + if (server.bgsavechildpid == -1 && + server.bgrewritechildpid == -1 && + server.auto_aofrewrite_perc && server.appendonly_current_size > server.auto_aofrewrite_min_size) { int base = server.auto_aofrewrite_base_size ? server.auto_aofrewrite_base_size : 1; - long long growth = (server.appendonly_current_size*100/base); + long long growth = (server.appendonly_current_size*100/base) - 100; if (growth >= server.auto_aofrewrite_perc) { - redisLog(REDIS_NOTICE,"Starting automatic rewriting of AOF on %lld growth",growth); + redisLog(REDIS_NOTICE,"Starting automatic rewriting of AOF on %lld%% growth",growth); rewriteAppendOnlyFileBackground(); } } @@ -1393,6 +1395,16 @@ sds genRedisInfoString(char *section) { server.lastsave, server.bgrewritechildpid != -1); + if (server.appendonly) { + info = sdscatprintf(info, + "aof_current_size:%lld\r\n" + "aof_base_size:%lld\r\n" + "aof_pending_rewrite:%d\r\n", + (long long) server.appendonly_current_size, + (long long) server.auto_aofrewrite_base_size, + server.aofrewrite_scheduled); + } + if (server.loading) { double perc; time_t eta, elapsed;