1. 09 6月, 2014 3 次提交
    • M
      Fix lack of strtold under Cygwin · 8f774ee7
      Matt Stancliff 提交于
      Renaming strtold to strtod then casting
      the result is the standard way of dealing with
      no strtold in Cygwin.
      8f774ee7
    • M
      Fix lack of SA_ONSTACK under Cygwin · 2af24143
      Matt Stancliff 提交于
      Fixes #232
      2af24143
    • M
      Fix blocking operations from missing new lists · b4f9761d
      Matt Stancliff 提交于
      Behrad Zari discovered [1] and Josiah reported [2]: if you block
      and wait for a list to exist, but the list creates from
      a non-push command, the blocked client never gets notified.
      
      This commit adds notification of blocked clients into
      the DB layer and away from individual commands.
      
      Lists can be created by [LR]PUSH, SORT..STORE, RENAME, MOVE,
      and RESTORE.  Previously, blocked client notifications were
      only triggered by [LR]PUSH.  Your client would never get
      notified if a list were created by SORT..STORE or RENAME or
      a RESTORE, etc.
      
      Blocked client notification now happens in one unified place:
        - dbAdd() triggers notification when adding a list to the DB
      
      Two new tests are added that fail prior to this commit.
      
      All test pass.
      
      Fixes #1668
      
      [1]: https://groups.google.com/forum/#!topic/redis-db/k4oWfMkN1NU
      [2]: #1668
      b4f9761d
  2. 06 6月, 2014 4 次提交
  3. 05 6月, 2014 6 次提交
    • A
      Redis 2.8.10. · 987a47b8
      antirez 提交于
      987a47b8
    • A
      Don't process min-slaves-to-write for slaves. · 430bec34
      antirez 提交于
      Replication is totally broken when a slave has this option, since it
      stops accepting updates from masters.
      
      This fixes issue #1434.
      430bec34
    • A
      Tests for min-slaves-* feature. · 3a30be51
      antirez 提交于
      3a30be51
    • A
      Fixed dbuf variable scope in luaRedisGenericCommand(). · 42504169
      antirez 提交于
      I'm not sure if while the visibility is the inner block, the fact we
      point to 'dbuf' is a problem or not, probably the stack var isx
      guaranteed to live until the function returns. However obvious code is
      better anyway.
      42504169
    • A
      Regression test for issue #1118. · 26359d57
      antirez 提交于
      26359d57
    • A
      Scripting: better Lua number -> string conversion in luaRedisGenericCommand(). · 768994b6
      antirez 提交于
      The lua_to*string() family of functions use a non optimal format
      specifier when converting integers to strings. This has both the problem
      of the number being converted in exponential notation, which we don't
      use as a Redis return value when floating point numbers are involed,
      and, moreover, there is a loss of precision since the default format
      specifier is not able to represent numbers that must be represented
      exactly in the IEEE 754 number mantissa.
      
      The new code handles it as a special case using a saner conversion.
      
      This fixes issue #1118.
      768994b6
  4. 28 5月, 2014 1 次提交
  5. 26 5月, 2014 2 次提交
  6. 22 5月, 2014 4 次提交
    • A
      Test: fixed scripting.tcl test false positive. · 1a14eba2
      antirez 提交于
      1a14eba2
    • A
      Process events with processEventsWhileBlocked() when blocked. · f4823497
      antirez 提交于
      When we are blocked and a few events a processed from time to time, it
      is smarter to call the event handler a few times in order to handle the
      accept, read, write, close cycle of a client in a single pass, otherwise
      there is too much latency added for clients to receive a reply while the
      server is busy in some way (for example during the DB loading).
      f4823497
    • A
      Accept multiple clients per iteration. · f3d3c606
      antirez 提交于
      When the listening sockets readable event is fired, we have the chance
      to accept multiple clients instead of accepting a single one. This makes
      Redis more responsive when there is a mass-connect event (for example
      after the server startup), and in workloads where a connect-disconnect
      pattern is used often, so that multiple clients are waiting to be
      accepted continuously.
      
      As a side effect, this commit makes the LOADING, BUSY, and similar
      errors much faster to deliver to the client, making Redis more
      responsive when there is to return errors to inform the clients that the
      server is blocked in an not interruptible operation.
      f3d3c606
    • A
      While ANET_ERR is -1, check syscall retval for -1 itself. · 41134739
      antirez 提交于
      41134739
  7. 20 5月, 2014 4 次提交
  8. 19 5月, 2014 2 次提交
  9. 15 5月, 2014 1 次提交
  10. 12 5月, 2014 3 次提交
  11. 09 5月, 2014 1 次提交
  12. 08 5月, 2014 2 次提交
    • A
      Sentinel: log when a failover will be attempted again. · 13d8b2b0
      antirez 提交于
      When a Sentinel performs a failover (successful or not), or when a
      Sentinel votes for a different Sentinel trying to start a failover, it
      sets a min delay before it will try to get elected for a failover.
      
      While not strictly needed, because if multiple Sentinels will try
      to failover the same master at the same time, only one configuration
      will eventually win, this serialization is practically very useful.
      Normal failovers are cleaner: one Sentinel starts to failover, the
      others update their config when the Sentinel performing the failover
      is able to get the selected slave to move from the role of slave to the
      one of master.
      
      However currently this timeout was implicit, so users could see
      Sentinels not reacting, after a failed failover, for some time, without
      giving any feedback in the logs to the poor sysadmin waiting for clues.
      
      This commit makes Sentinels more verbose about the delay: when a master
      is down and a failover attempt is not performed because the delay has
      still not elaped, something like that will be logged:
      
          Next failover delay: I will not start a failover
          before Thu May  8 16:48:59 2014
      13d8b2b0
    • A
      Sentinel: generate +config-update-from event when a new config is received. · 909d1883
      antirez 提交于
      This event makes clear, before the switch-master event is generated,
      that a Sentinel received a configuration update from another Sentinel.
      909d1883
  13. 07 5月, 2014 7 次提交
    • A
      Scripting test: check that Lua can call commands rewirting argv. · 80b96bc4
      antirez 提交于
      SPOP, tested in the new test, is among the commands rewritng the
      client->argv argument vector (it gets rewritten as SREM) for command
      replication purposes.
      
      Because of recent optimizations to client->argv caching in the context
      of the Lua internal Redis client, it is important to test for SPOP to be
      callable from Lua without bad effects to the other commands.
      80b96bc4
    • A
      Test: handle new osx 'leaks' error. · 093eab56
      antirez 提交于
      Sometimes the process is still there but no longer in a state that can
      be checked (after being killed). This used to happen after a call to
      SHUTDOWN NOSAVE in the scripting unit, causing a false positive.
      093eab56
    • A
      Scripting: objects caching for Lua c->argv creation. · 32971f62
      antirez 提交于
      Reusing small objects when possible is a major speedup under certain
      conditions, since it is able to avoid the malloc/free pattern that
      otherwise is performed for every argument in the client command vector.
      32971f62
    • A
      Scripting: Use faster API for Lua client c->argv creation. · 87516f1a
      antirez 提交于
      Replace the three calls to Lua API lua_tostring, lua_lua_strlen,
      and lua_isstring, with a single call to lua_tolstring.
      
      ~ 5% consistent speed gain measured.
      87516f1a
    • A
      Scripting: don't call lua_gc() after Lua script run. · 1b5524f6
      antirez 提交于
      Calling lua_gc() after every script execution is too expensive, and
      apparently does not make the execution smoother: the same peak latency
      was measured before and after the commit.
      
      This change accounts for scripts execution speedup in the order of 10%.
      1b5524f6
    • A
      Scripting: cache argv in luaRedisGenericCommand(). · 8237d88f
      antirez 提交于
      ~ 4% consistently measured speed improvement.
      8237d88f
    • A
      Fixed missing c->bufpos reset in luaRedisGenericCommand(). · 6938a3d5
      antirez 提交于
      Bug introduced when adding a fast path to avoid copying the reply buffer
      for small replies that fit into the client static buffer.
      6938a3d5