]> git.saurik.com Git - redis.git/commitdiff
Fixed a race condition in VM happening when a key was deleted while there was a clien...
authorantirez <antirez@gmail.com>
Wed, 8 Sep 2010 11:26:16 +0000 (13:26 +0200)
committerantirez <antirez@gmail.com>
Wed, 8 Sep 2010 11:26:16 +0000 (13:26 +0200)
src/db.c

index f380bf6ec05882c6e79ec3993608e68d8e96c168..ca520c8259d0b7758baf11fd0037345b653885af 100644 (file)
--- a/src/db.c
+++ b/src/db.c
@@ -123,6 +123,11 @@ robj *dbRandomKey(redisDb *db) {
 
 /* Delete a key, value, and associated expiration entry if any, from the DB */
 int dbDelete(redisDb *db, robj *key) {
+    /* If VM is enabled make sure to awake waiting clients for this key:
+     * deleting the key will kill the I/O thread bringing the key from swap
+     * to memory, so the client will never be notified and unblocked if we
+     * don't do it now. */
+    handleClientsBlockedOnSwappedKey(db,key);
     /* Deleting an entry from the expires dict will not free the sds of
      * the key, because it is shared with the main dictionary. */
     if (dictSize(db->expires) > 0) dictDelete(db->expires,key->ptr);