1. 05 6月, 2014 1 次提交
    • A
      Scripting: better Lua number -> string conversion in luaRedisGenericCommand(). · 072982d8
      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.
      072982d8
  2. 28 5月, 2014 1 次提交
  3. 27 5月, 2014 1 次提交
  4. 26 5月, 2014 5 次提交
  5. 24 5月, 2014 1 次提交
    • M
      Fix test framework to detect proper server PID · 6c16ecaa
      Matt Stancliff 提交于
      Previously the PID format was:
      [PID] Timestamp
      
      But it recently changed to:
      PID:X Timestamp
      
      The tcl testing framework was grabbing the PID from \[\d+\], but
      that's not valid anymore.
      
      Now we grab the pid from "PID: <PID>" in the part of Redis startup
      output to the right of the ASCII logo.
      6c16ecaa
  6. 23 5月, 2014 5 次提交
  7. 22 5月, 2014 4 次提交
  8. 21 5月, 2014 2 次提交
  9. 20 5月, 2014 6 次提交
  10. 19 5月, 2014 5 次提交
  11. 18 5月, 2014 1 次提交
  12. 15 5月, 2014 5 次提交
    • A
      Cluster: use clusterSetNodeAsMaster() during slave failover. · 67133d2f
      antirez 提交于
      clusterHandleSlaveFailover() was reimplementing what
      clusterSetNodeAsMaster() without any good reason.
      67133d2f
    • A
      Cluster: clear todo_before_sleep flags when executing actions. · 8c6e92c3
      antirez 提交于
      Thanks to this change, when there is some code like:
      
          clusterDoBeforeSleep(CLUSTER_TODO_UPDATE_STATE|...);
          ... and later before returning to the event loop ...
          clusterUpdateState();
      
      The clusterUpdateState() function will clar the flag and will not be
      repeated in the clusterBeforeSleep() function. This especially important
      for config save/fsync flags which are slow to execute and not a good
      idea to repeat without a good reason.
      
      This is implemented for all the CLUSTER_TODO flags.
      8c6e92c3
    • A
      Fixed typo in CLUSTER RESET implementation. · 7b87cda7
      antirez 提交于
      7b87cda7
    • A
      CLUSTER RESET implemented. · 796f4ae9
      antirez 提交于
      The new command is able to reset a cluster node so that it starts again
      as a fresh node. By default the command performs a soft reset (the same
      as calling it as CLUSTER RESET SOFT), and the following steps are
      performed:
      
      1) All slots are set as unassigned.
      2) The list of known nodes is flushed.
      3) Node is set as master if it is a slave.
      
      When an hard reset is performed with CLUSTER RESET HARD the following
      additional operations are performed:
      
      4) A new Node ID is created at random.
      5) Epochs are set to 0.
      
      CLUSTER RESET is useful both when the sysadmin wants to reconfigure a
      node with a different role (for example turning a slave into a master)
      and for testing purposes.
      
      It also may play a role in automatically provisioned Redis Clusters,
      since it allows to reset a node back to the initial state in order to be
      reconfigured.
      796f4ae9
    • A
      Remove trailing spaces from cluster.c file. · 8b9d5ecb
      antirez 提交于
      8b9d5ecb
  13. 14 5月, 2014 3 次提交
    • A
      Cluster test: added function assert_cluster_state. · 0b7aa261
      antirez 提交于
      0b7aa261
    • A
      60e5d172
    • A
      Cluster: better handling of stolen slots. · 6baac558
      antirez 提交于
      The previous code handling a lost slot (by another master with an higher
      configuration for the slot) was defensive, considering it an error and
      putting the cluster in an odd state requiring redis-cli fix.
      
      This was changed, because actually this only happens either in a
      legitimate way, with failovers, or when the admin messed with the config
      in order to reconfigure the cluster. So the new code instead will try to
      make sure that the keys stored match the new slots map, by removing all
      the keys in the slots we lost ownership from.
      
      The function that deletes the keys from the lost slots is called only
      if the node does not lose all its slots (resulting in a reconfiguration
      as a slave of the node that got ownership). This is an optimization
      since the replication code will anyway flush all the instance data in
      a faster way.
      6baac558