mirror of
https://codeberg.org/redict/redict.git
synced 2025-01-22 16:18:28 -05:00
Throttle BGSAVE attempt on saving error.
When a BGSAVE fails, Redis used to flood itself trying to BGSAVE at every next cron call, that is either 10 or 100 times per second depending on configuration and server version. This commit does not allow a new automatic BGSAVE attempt to be performed before a few seconds delay (currently 5). This avoids both the auto-flood problem and filling the disk with logs at a serious rate. The five seconds limit, considering a log entry of 200 bytes, will use less than 4 MB of disk space per day that is reasonable, the sysadmin should notice before of catastrofic events especially since by default Redis will stop serving write queries after the first failed BGSAVE. This fixes issue #849
This commit is contained in:
parent
b14fda7deb
commit
b237de33d1
@ -722,6 +722,7 @@ int rdbSaveBackground(char *filename) {
|
|||||||
if (server.rdb_child_pid != -1) return REDIS_ERR;
|
if (server.rdb_child_pid != -1) return REDIS_ERR;
|
||||||
|
|
||||||
server.dirty_before_bgsave = server.dirty;
|
server.dirty_before_bgsave = server.dirty;
|
||||||
|
server.lastbgsave_try = time(NULL);
|
||||||
|
|
||||||
start = ustime();
|
start = ustime();
|
||||||
if ((childpid = fork()) == 0) {
|
if ((childpid = fork()) == 0) {
|
||||||
|
13
src/redis.c
13
src/redis.c
@ -1024,8 +1024,16 @@ int serverCron(struct aeEventLoop *eventLoop, long long id, void *clientData) {
|
|||||||
for (j = 0; j < server.saveparamslen; j++) {
|
for (j = 0; j < server.saveparamslen; j++) {
|
||||||
struct saveparam *sp = server.saveparams+j;
|
struct saveparam *sp = server.saveparams+j;
|
||||||
|
|
||||||
|
/* Save if we reached the given amount of changes,
|
||||||
|
* the given amount of seconds, and if the latest bgsave was
|
||||||
|
* successful or if, in case of an error, at least
|
||||||
|
* REDIS_BGSAVE_RETRY_DELAY seconds already elapsed. */
|
||||||
if (server.dirty >= sp->changes &&
|
if (server.dirty >= sp->changes &&
|
||||||
server.unixtime-server.lastsave > sp->seconds) {
|
server.unixtime-server.lastsave > sp->seconds &&
|
||||||
|
(server.unixtime-server.lastbgsave_try >
|
||||||
|
REDIS_BGSAVE_RETRY_DELAY ||
|
||||||
|
server.lastbgsave_status == REDIS_OK))
|
||||||
|
{
|
||||||
redisLog(REDIS_NOTICE,"%d changes in %d seconds. Saving...",
|
redisLog(REDIS_NOTICE,"%d changes in %d seconds. Saving...",
|
||||||
sp->changes, (int)sp->seconds);
|
sp->changes, (int)sp->seconds);
|
||||||
rdbSaveBackground(server.rdb_filename);
|
rdbSaveBackground(server.rdb_filename);
|
||||||
@ -1439,7 +1447,8 @@ void initServer() {
|
|||||||
server.aof_child_pid = -1;
|
server.aof_child_pid = -1;
|
||||||
aofRewriteBufferReset();
|
aofRewriteBufferReset();
|
||||||
server.aof_buf = sdsempty();
|
server.aof_buf = sdsempty();
|
||||||
server.lastsave = time(NULL);
|
server.lastsave = time(NULL); /* At startup we consider the DB saved. */
|
||||||
|
server.lastbgsave_try = 0; /* At startup we never tried to BGSAVE. */
|
||||||
server.rdb_save_time_last = -1;
|
server.rdb_save_time_last = -1;
|
||||||
server.rdb_save_time_start = -1;
|
server.rdb_save_time_start = -1;
|
||||||
server.dirty = 0;
|
server.dirty = 0;
|
||||||
|
@ -97,6 +97,7 @@
|
|||||||
#define REDIS_DEFAULT_REPL_BACKLOG_SIZE (1024*1024) /* 1mb */
|
#define REDIS_DEFAULT_REPL_BACKLOG_SIZE (1024*1024) /* 1mb */
|
||||||
#define REDIS_DEFAULT_REPL_BACKLOG_TIME_LIMIT (60*60) /* 1 hour */
|
#define REDIS_DEFAULT_REPL_BACKLOG_TIME_LIMIT (60*60) /* 1 hour */
|
||||||
#define REDIS_REPL_BACKLOG_MIN_SIZE (1024*16) /* 16k */
|
#define REDIS_REPL_BACKLOG_MIN_SIZE (1024*16) /* 16k */
|
||||||
|
#define REDIS_BGSAVE_RETRY_DELAY 5 /* Wait a few secs before trying again. */
|
||||||
|
|
||||||
/* Protocol and I/O related defines */
|
/* Protocol and I/O related defines */
|
||||||
#define REDIS_MAX_QUERYBUF_LEN (1024*1024*1024) /* 1GB max query buffer. */
|
#define REDIS_MAX_QUERYBUF_LEN (1024*1024*1024) /* 1GB max query buffer. */
|
||||||
@ -764,6 +765,7 @@ struct redisServer {
|
|||||||
int rdb_compression; /* Use compression in RDB? */
|
int rdb_compression; /* Use compression in RDB? */
|
||||||
int rdb_checksum; /* Use RDB checksum? */
|
int rdb_checksum; /* Use RDB checksum? */
|
||||||
time_t lastsave; /* Unix time of last successful save */
|
time_t lastsave; /* Unix time of last successful save */
|
||||||
|
time_t lastbgsave_try; /* Unix time of last attempted bgsave */
|
||||||
time_t rdb_save_time_last; /* Time used by last RDB save run. */
|
time_t rdb_save_time_last; /* Time used by last RDB save run. */
|
||||||
time_t rdb_save_time_start; /* Current RDB save start time. */
|
time_t rdb_save_time_start; /* Current RDB save start time. */
|
||||||
int lastbgsave_status; /* REDIS_OK or REDIS_ERR */
|
int lastbgsave_status; /* REDIS_OK or REDIS_ERR */
|
||||||
|
Loading…
Reference in New Issue
Block a user