1. 03 12月, 2012 1 次提交
    • A
      Blocking POP: use a dictionary to store keys clinet side. · 54b08c86
      antirez 提交于
      To store the keys we block for during a blocking pop operation, in the
      case the client is blocked for more data to arrive, we used a simple
      linear array of redis objects, in the blockingState structure:
      
          robj **keys;
          int count;
      
      However in order to fix issue #801 we also use a dictionary in order to
      avoid to end in the blocked clients queue for the same key multiple
      times with the same client.
      
      The dictionary was only temporary, just to avoid duplicates, but since
      we create / destroy it there is no point in doing this duplicated work,
      so this commit simply use a dictionary as the main structure to store
      the keys we are blocked for. So instead of the previous fields we now
      just have:
      
          dict *keys;
      
      This simplifies the code and reduces the work done by the server during
      a blocking POP operation.
      54b08c86
  2. 02 12月, 2012 1 次提交
  3. 01 12月, 2012 1 次提交
    • A
      Client should not block multiple times on the same key. · cac49a90
      antirez 提交于
      Sending a command like:
      
      BLPOP foo foo foo foo 0
      
      Resulted into a crash before this commit since the client ended being
      inserted in the waiting list for this key multiple times.
      This resulted into the function handleClientsBlockedOnLists() to fail
      because we have code like that:
      
          if (de) {
              list *clients = dictGetVal(de);
              int numclients = listLength(clients);
      
              while(numclients--) {
                  listNode *clientnode = listFirst(clients);
      
                  /* server clients here... */
              }
          }
      
      The code to serve clients used to remove the served client from the
      waiting list, so if a client is blocking multiple times, eventually the
      call to listFirst() will return NULL or worse will access random memory
      since the list may no longer exist as it is removed by the function
      unblockClientWaitingData() if there are no more clients waiting for this
      list.
      
      To avoid making the rest of the implementation more complex, this commit
      modifies blockForKeys() so that a client will be put just a single time
      into the waiting list for a given key.
      
      Since it is Saturday, I hope this fixes issue #801.
      cac49a90
  4. 29 11月, 2012 3 次提交
  5. 23 11月, 2012 1 次提交
  6. 22 11月, 2012 6 次提交
    • A
      EVALSHA is now case insensitive. · 9120275d
      antirez 提交于
      EVALSHA used to crash if the SHA1 was not lowercase (Issue #783).
      Fixed using a case insensitive dictionary type for the sha -> script
      map used for replication of scripts.
      9120275d
    • A
      Fix integer overflow in zunionInterGenericCommand(). · de00a5a0
      antirez 提交于
      This fixes issue #761.
      de00a5a0
    • A
      Test: MULTI state is cleared after EXECABORT error. · 2b45ef02
      antirez 提交于
      2b45ef02
    • A
      52bd3d8a
    • A
      Test: MULTI/EXEC tests moved into multi.tcl. · 37d978d9
      antirez 提交于
      37d978d9
    • A
      Safer handling of MULTI/EXEC on errors. · 41f0f927
      antirez 提交于
      After the transcation starts with a MULIT, the previous behavior was to
      return an error on problems such as maxmemory limit reached. But still
      to execute the transaction with the subset of queued commands on EXEC.
      
      While it is true that the client was able to check for errors
      distinguish QUEUED by an error reply, MULTI/EXEC in most client
      implementations uses pipelining for speed, so all the commands and EXEC
      are sent without caring about replies.
      
      With this change:
      
      1) EXEC fails if at least one command was not queued because of an
      error. The EXECABORT error is used.
      2) A generic error is always reported on EXEC.
      3) The client DISCARDs the MULTI state after a failed EXEC, otherwise
      pipelining multiple transactions would be basically impossible:
      After a failed EXEC the next transaction would be simply queued as
      the tail of the previous transaction.
      41f0f927
  7. 20 11月, 2012 2 次提交
    • A
      Children creating AOF or RDB files now report memory used by COW. · 5ab4151d
      antirez 提交于
      Finally Redis is able to report the amount of memory used by
      copy-on-write while saving an RDB or writing an AOF file in background.
      
      Note that this information is currently only logged (at NOTICE level)
      and not shown in INFO because this is less trivial (but surely doable
      with some minor form of interprocess communication).
      
      The reason we can't capture this information on the parent before we
      call wait3() is that the Linux kernel will release the child memory
      ASAP, and only retain the minimal state for the process that is useful
      to report the child termination to the parent.
      
      The COW size is obtained by summing all the Private_Dirty fields found
      in the "smap" file inside the proc filesystem for the process.
      
      All this is Linux specific and is not available on other systems.
      5ab4151d
    • A
      zmalloc_get_private_dirty() function added (Linux only). · e95ca663
      antirez 提交于
      For non Linux systmes it just returns 0.
      
      This function is useful to estimate copy-on-write because of childs
      saving stuff on disk.
      e95ca663
  8. 14 11月, 2012 1 次提交
  9. 13 11月, 2012 3 次提交
  10. 09 11月, 2012 4 次提交
  11. 07 11月, 2012 1 次提交
  12. 02 11月, 2012 4 次提交
  13. 01 11月, 2012 2 次提交
  14. 31 10月, 2012 4 次提交
  15. 26 10月, 2012 6 次提交