Skip to content

Commit

Permalink
fixed diskstore race condition
Browse files Browse the repository at this point in the history
  • Loading branch information
antirez committed Mar 10, 2011
1 parent dc75b1e commit 7493d2a
Showing 1 changed file with 10 additions and 2 deletions.
12 changes: 10 additions & 2 deletions src/dscache.c
Original file line number Diff line number Diff line change
Expand Up @@ -890,8 +890,16 @@ int waitForSwappedKey(redisClient *c, robj *key) {
listAddNodeTail(l,c);

/* Are we already loading the key from disk? If not create a job */
if (de == NULL)
cacheScheduleIO(c->db,key,REDIS_IO_LOAD);
if (de == NULL) {
int flags = cacheScheduleIOGetFlags(c->db,key);

/* It is possible that even if there are no clients waiting for
* a load operation, still we have a load operation in progress.
* For instance think to a client performing a GET and then
* closing the connection */
if ((flags & (REDIS_IO_LOAD|REDIS_IO_LOADINPROG)) == 0)
cacheScheduleIO(c->db,key,REDIS_IO_LOAD);
}
return 1;
}

Expand Down

0 comments on commit 7493d2a

Please sign in to comment.