1. 20 1月, 2014 1 次提交
  2. 18 1月, 2014 3 次提交
  3. 17 1月, 2014 6 次提交
  4. 16 1月, 2014 2 次提交
  5. 15 1月, 2014 9 次提交
    • A
      Cluster: use the node blacklist in CLUSTER FORGET. · 3e948970
      antirez 提交于
      CLUSTER FORGET is not useful if we can't remove a node from all the
      nodes of our cluster because of the Gossip protocol that keeps adding
      a given node to nodes where we already tried to remove it.
      
      So now CLUSTER FORGET implements a nodes blacklist that is set and
      checked by the Gossip section processing function. This way before a
      node is re-added at least 60 seconds must elapse since the FORGET
      execution.
      
      This means that redis-trib has some time to remove a node from a whole
      cluster. It is possible that in the future it will be uesful to raise
      the 60 sec figure to something bigger.
      3e948970
    • A
      Cluster: fix clusterBlacklistAddNode() by setting right expire time. · ccf268fa
      antirez 提交于
      The hash table value should be set to now + 60 seconds otherwise it
      expires immediately.
      ccf268fa
    • A
      Cluster: clusterBlacklistAddNode() key lookup fixed. · 4e186115
      antirez 提交于
      We can't lookup by node->name that's not an SDS string but a plain C
      array in the node structure.
      4e186115
    • A
    • A
      Cluster: set a minimum rejoin delay if node_timeout is too small. · a81340ab
      antirez 提交于
      The rejoin delay usually is the node timeout. However if the node
      timeout is too small, we set it to 500 milliseconds, that is a value
      chosen to be greater than most setups RTT / instances latency figures
      so that likely communication with other nodes happen before rejoining.
      a81340ab
    • A
      Cluster: periodically call clusterUpdateState() when cluster is down. · a687cbc1
      antirez 提交于
      Usually we update the cluster state (to understand if we should accept
      queries or reply with an error) only when there is a change in the state
      of the nodes. However for the "delayed rejoin" feature to work, that is,
      for a master to wait some time before accepting queries again after it
      rejoins the majority, we need to periodically update the last time when
      the node was partitioned away from the majority.
      
      With this commit if the cluster is down we update the state ten times
      per second.
      a687cbc1
    • A
      Cluster: range checking in getSlotOrReply() fixed. · 25ddefde
      antirez 提交于
      See issue #1426 on Github.
      25ddefde
    • A
      Cluster: ignore empty lines in nodes.conf. · fb659cd3
      antirez 提交于
      Even without the user messing manually with the file, it is still
      possible to have blank lines (just a single "\n" per line) because of
      how the nodes.conf update/write process works.
      fb659cd3
    • A
      Cluster: atomic update of nodes.conf file. · 6c63df30
      antirez 提交于
      The way the file was generated was unsafe and leaded to nodes.conf file
      corruption (zero length file) on server stop/crash during the creation
      of the file.
      
      The previous file update method was as simple as open with O_TRUNC
      followed by the write call. While the write call was a single one with
      the full payload, ensuring no half-written files for POSIX semantics,
      stopping the server just after the open call resulted into a zero-length
      file (all the nodes information lost!).
      6c63df30
  6. 14 1月, 2014 4 次提交
  7. 13 1月, 2014 3 次提交
  8. 10 1月, 2014 9 次提交
  9. 09 1月, 2014 3 次提交