1. 17 1月, 2014 6 次提交
  2. 16 1月, 2014 2 次提交
  3. 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
  4. 14 1月, 2014 4 次提交
  5. 13 1月, 2014 3 次提交
  6. 10 1月, 2014 9 次提交
  7. 09 1月, 2014 4 次提交
  8. 08 1月, 2014 2 次提交
    • A
      Don't send REPLCONF ACK to old masters. · 90a81b4e
      antirez 提交于
      Masters not understanding REPLCONF ACK will reply with errors to our
      requests causing a number of possible issues.
      
      This commit detects a global replication offest set to -1 at the end of
      the replication, and marks the client representing the master with the
      REDIS_PRE_PSYNC flag.
      
      Note that this flag was called REDIS_PRE_PSYNC_SLAVE but now it is just
      REDIS_PRE_PSYNC as it is used for both slaves and masters starting with
      this commit.
      
      This commit fixes issue #1488.
      90a81b4e
    • A
      Clarify a comment in slaveTryPartialResynchronization(). · 3f92e056
      antirez 提交于
      3f92e056
  9. 26 12月, 2013 1 次提交