1. 29 10月, 2013 6 次提交
  2. 27 6月, 2013 1 次提交
  3. 28 3月, 2013 1 次提交
  4. 26 3月, 2013 1 次提交
    • A
      TTL / PTTL commands: two bugs fixed. · a452b548
      antirez 提交于
      This commit fixes two corner cases for the TTL command.
      
      1) When the key was already logically expired (expire time older
      than current time) the command returned -1 instead of -2.
      
      2) When the key was existing and the expire was found to be exactly 0
      (the key was just about to expire), the command reported -1 (that is, no
      expire) instead of a TTL of zero (that is, about to expire).
      a452b548
  5. 12 2月, 2013 1 次提交
  6. 28 1月, 2013 5 次提交
  7. 19 1月, 2013 2 次提交
    • A
      Whitelist SIGUSR1 to avoid auto-triggering errors. · 39f0a33f
      antirez 提交于
      This commit fixes issue #875 that was caused by the following events:
      
      1) There is an active child doing BGSAVE.
      2) flushall is called (or any other condition that makes Redis killing
      the saving child process).
      3) An error is sensed by Redis as the child exited with an error (killed
      by a singal), that stops accepting write commands until a BGSAVE happens
      to be executed with success.
      
      Whitelisting SIGUSR1 and making sure Redis always uses this signal in
      order to kill its own children fixes the issue.
      39f0a33f
    • G
      Fixed many typos. · 1caf0939
      guiquanz 提交于
      Conflicts fixed, mainly because 2.8 has no cluster support / files:
      	00-RELEASENOTES
      	src/cluster.c
      	src/crc16.c
      	src/redis-trib.rb
      	src/redis.h
      1caf0939
  8. 13 11月, 2012 1 次提交
    • A
      TTL API change: TTL returns -2 for non existing keys. · 50c41de7
      antirez 提交于
      The previous behavior was to return -1 if:
      
      1) Existing key but without an expire set.
      2) Non existing key.
      
      Now the second case is handled in a different, and TTL will return -2
      if the key does not exist at all.
      
      PTTL follows the same behavior as well.
      50c41de7
  9. 09 11月, 2012 1 次提交
  10. 11 9月, 2012 1 次提交
    • A
      Make sure that SELECT argument is an integer or return an error. · b58f03a0
      antirez 提交于
      Unfortunately we had still the lame atoi() without any error checking in
      place, so "SELECT foo" would work as "SELECT 0". This was not an huge
      problem per se but some people expected that DB can be strings and not
      just numbers, and without errors you get the feeling that they can be
      numbers, but not the behavior.
      
      Now getLongFromObjectOrReply() is used as almost everybody else across
      the code, generating an error if the number is not an integer or
      overflows the long type.
      
      Thanks to @mipearson for reporting that on Twitter.
      b58f03a0
  11. 01 5月, 2012 1 次提交
    • P
      Use safe dictionary iterator from KEYS · 9311d2b5
      Pieter Noordhuis 提交于
      Every matched key in a KEYS call is checked for expiration. When the key
      is set to expire, the call to `getExpire` will assert that the key also
      exists in the main dictionary. This in turn causes a rehashing step to
      be executed. Rehashing a dictionary when there is an iterator active may
      result in the iterator emitting duplicate entries, or not emitting some
      entries at all. By using a safe iterator, the rehash step is omitted.
      9311d2b5
  12. 07 4月, 2012 1 次提交
  13. 06 4月, 2012 3 次提交
  14. 28 3月, 2012 2 次提交
  15. 10 3月, 2012 1 次提交
  16. 04 2月, 2012 1 次提交
  17. 02 2月, 2012 1 次提交
  18. 30 1月, 2012 1 次提交
  19. 21 12月, 2011 3 次提交
  20. 18 11月, 2011 1 次提交
  21. 11 11月, 2011 1 次提交
  22. 10 11月, 2011 1 次提交
  23. 09 11月, 2011 2 次提交
  24. 17 10月, 2011 1 次提交