1. 07 8月, 2015 1 次提交
  2. 06 8月, 2015 4 次提交
    • A
      flushSlavesOutputBuffers(): details clarified via comments. · 55cb64bb
      antirez 提交于
      Talking with @oranagra we had to reason a little bit to understand if
      this function could ever flush the output buffers of the wrong slaves,
      having online state but actually not being ready to receive writes
      before the first ACK is received from them (this happens with diskless
      replication).
      
      Next time we'll just read this comment.
      55cb64bb
    • A
      startBgsaveForReplication(): log what you really do. · ce5761e0
      antirez 提交于
      ce5761e0
    • A
      Client structure comments improved. · fd08839a
      antirez 提交于
      fd08839a
    • A
      Replication: add REPLCONF CAPA EOF support. · 3e6d4d59
      antirez 提交于
      Add the concept of slaves capabilities to Redis, the slave now presents
      to the Redis master with a set of capabilities in the form:
      
          REPLCONF capa SOMECAPA capa OTHERCAPA ...
      
      This has the effect of setting slave->slave_capa with the corresponding
      SLAVE_CAPA macros that the master can test later to understand if it
      the slave will understand certain formats and protocols of the
      replication process. This makes it much simpler to introduce new
      replication capabilities in the future in a way that don't break old
      slaves or masters.
      
      This patch was designed and implemented together with Oran Agra
      (@oranagra).
      3e6d4d59
  3. 05 8月, 2015 9 次提交
  4. 04 8月, 2015 2 次提交
    • A
      PSYNC initial offset fix. · 292fec05
      antirez 提交于
      This commit attempts to fix a bug involving PSYNC and diskless
      replication (currently experimental) found by Yuval Inbar from Redis Labs
      and that was later found to have even more far reaching effects (the bug also
      exists when diskstore is off).
      
      The gist of the bug is that, a Redis master replies with +FULLRESYNC to
      a PSYNC attempt that fails and requires a full resynchronization.
      However, the baseline offset sent along with FULLRESYNC was always the
      current master replication offset. This is not ok, because there are
      many reasosn that may delay the RDB file creation. And... guess what,
      the master offset we communicate must be the one of the time the RDB
      was created. So for example:
      
      1) When the BGSAVE for replication is delayed since there is one
         already but is not good for replication.
      2) When the BGSAVE is not needed as we attach one currently ongoing.
      3) When because of diskless replication the BGSAVE is delayed.
      
      In all the above cases the PSYNC reply is wrong and the slave may
      reconnect later claiming to need a wrong offset: this may cause
      data curruption later.
      292fec05
    • A
      Test PSYNC with diskless replication. · d1ff3281
      antirez 提交于
      Thanks to Oran Agra from Redis Labs for providing this patch.
      d1ff3281
  5. 29 7月, 2015 2 次提交
  6. 28 7月, 2015 8 次提交
  7. 27 7月, 2015 4 次提交
  8. 26 7月, 2015 5 次提交
  9. 25 7月, 2015 5 次提交