1. 26 6月, 2013 2 次提交
  2. 25 6月, 2013 1 次提交
  3. 24 6月, 2013 1 次提交
    • A
      Replication of scripts as EVALSHA: sha1 caching implemented. · 94ec7db4
      antirez 提交于
      This code is only responsible to take an LRU-evicted fixed length cache
      of SHA1 that we are sure all the slaves received.
      
      In this commit only the implementation is provided, but the Redis core
      does not use it to actually send EVALSHA to slaves when possible.
      94ec7db4
  4. 21 6月, 2013 1 次提交
    • A
      New API to force propagation. · 515a26bb
      antirez 提交于
      The old REDIS_CMD_FORCE_REPLICATION flag was removed from the
      implementation of Redis, now there is a new API to force specific
      executions of a command to be propagated to AOF / Replication link:
      
          void forceCommandPropagation(int flags);
      
      The new API is also compatible with Lua scripting, so a script that will
      execute commands that are forced to be propagated, will also be
      propagated itself accordingly even if no change to data is operated.
      
      As a side effect, this new design fixes the issue with scripts not able
      to propagate PUBLISH to slaves (issue #873).
      515a26bb
  5. 20 6月, 2013 1 次提交
    • A
      PUBSUB command implemented. · 455563fa
      antirez 提交于
      Currently it implements three subcommands:
      
      PUBSUB CHANNELS [<pattern>]    List channels with non-zero subscribers.
      PUBSUB NUMSUB [channel_1 ...]  List number of subscribers for channels.
      PUBSUB NUMPAT                  Return number of subscribed patterns.
      455563fa
  6. 13 6月, 2013 1 次提交
  7. 30 5月, 2013 1 次提交
  8. 28 5月, 2013 1 次提交
  9. 27 5月, 2013 2 次提交
    • A
      Replication: send REPLCONF ACK to master. · 0292c5f7
      antirez 提交于
      0292c5f7
    • A
      REPLCONF ACK command. · 6b4635f4
      antirez 提交于
      This special command is used by the slave to inform the master the
      amount of replication stream it currently consumed.
      
      it does not return anything so that we not need to consume additional
      bandwidth needed by the master to reply something.
      
      The master can do a number of things knowing the amount of stream
      processed, such as understanding the "lag" in bytes of the slave, verify
      if a given command was already processed by the slave, and so forth.
      6b4635f4
  10. 17 5月, 2013 1 次提交
  11. 15 5月, 2013 1 次提交
    • A
      Added a define for most configuration defaults. · 310dbba0
      antirez 提交于
      Also the logfile option was modified to always have an explicit value
      and to log to stdout when an empty string is used as log file.
      
      Previously there was special handling of the string "stdout" that set
      the logfile to NULL, this always required some special handling.
      310dbba0
  12. 14 5月, 2013 1 次提交
  13. 13 5月, 2013 1 次提交
  14. 09 5月, 2013 1 次提交
  15. 08 5月, 2013 1 次提交
    • A
      Revert "use long long instead of size_t make it more safe" · 0ae1b5b0
      antirez 提交于
      This reverts commit 2c75f2cf.
      
      After further analysis, it is very unlikely that we'll raise the
      string size limit to > 512MB, and at the same time such big strings
      will be used in 32 bit systems.
      
      Better to revert to size_t so that 32 bit processors will not be
      forced to use a 64 bit counter in normal operations, that is currently
      completely useless.
      0ae1b5b0
  16. 07 5月, 2013 2 次提交
  17. 03 5月, 2013 1 次提交
    • A
      Cluster: link reconnection on delayed PONG reply. · 5c9f6d4f
      antirez 提交于
      When the PONG delay is half the cluster node timeout, the link gets
      disconnected (and later automatically reconnected) in order to ensure
      that it's not just a dead connection issue.
      
      However this operation is only performed if the link is old enough, in
      order to avoid to disconnect the same link again and again (and among
      the other problems, never receive the PONG because of that).
      
      Note: when the link is reconnected, the 'ping_sent' field is not updated
      even if a new ping is sent using the new connection, so we can still
      reliably detect a node ping timeout.
      5c9f6d4f
  18. 24 4月, 2013 2 次提交
  19. 09 4月, 2013 2 次提交
    • A
      Cluster: use server.cluster_node_timeout directly. · 68cf249f
      antirez 提交于
      We used to copy this value into the server.cluster structure, however this
      was not necessary.
      
      The reason why we don't directly use server.cluster->node_timeout is
      that things that can be configured via redis.conf need to be directly
      available in the server structure as server.cluster is allocated later
      only if needed in order to reduce the memory footprint of non-cluster
      instances.
      68cf249f
    • A
      Cluster: configdigest field no longer used. Removed. · ef4f25ff
      antirez 提交于
      ef4f25ff
  20. 04 4月, 2013 3 次提交
  21. 02 4月, 2013 1 次提交
    • A
      Throttle BGSAVE attempt on saving error. · b237de33
      antirez 提交于
      When a BGSAVE fails, Redis used to flood itself trying to BGSAVE at
      every next cron call, that is either 10 or 100 times per second
      depending on configuration and server version.
      
      This commit does not allow a new automatic BGSAVE attempt to be
      performed before a few seconds delay (currently 5).
      
      This avoids both the auto-flood problem and filling the disk with
      logs at a serious rate.
      
      The five seconds limit, considering a log entry of 200 bytes, will use
      less than 4 MB of disk space per day that is reasonable, the sysadmin
      should notice before of catastrofic events especially since by default
      Redis will stop serving write queries after the first failed BGSAVE.
      
      This fixes issue #849
      b237de33
  22. 28 3月, 2013 1 次提交
    • A
      DEBUG set-active-expire added. · 32a83c82
      antirez 提交于
      We need the ability to disable the activeExpireCycle() (active
      expired key collection) call for testing purposes.
      32a83c82
  23. 20 3月, 2013 2 次提交
    • A
      Cluster: new flag PROMOTED introduced. · 506f9a42
      antirez 提交于
      A slave node set this flag for itself when, after receiving authorization
      from the majority of nodes, it turns itself into a master.
      
      At the same time now this flag is tested by nodes receiving a PING
      message before reconfiguring after a failover event. This makes the
      system more robust: even if currently there is no way to manually turn
      a slave into a master it is possible that we'll have such a feature in
      the future, or that simply because of misconfiguration a node joins the
      cluster as master while others believe it's a slave. This alone is now
      no longer enough to trigger reconfiguration as other nodes will check
      for the PROMOTED flag.
      
      The PROMOTED flag is cleared every time the node is turned back into a
      replica of some other node.
      506f9a42
    • A
      Cluster: add sender flags in cluster bus messages header. · 026b9483
      antirez 提交于
      Sender flags were not propagated for the sender, but only for nodes in
      the gossip section. This is odd and in the next commits we'll need to
      get updated flags for the sender node, so this commit adds a new field
      in the cluster messages header.
      
      The message header is the same size as we reused some free space that
      was marked as 'unused' because of alignment concerns.
      026b9483
  24. 15 3月, 2013 1 次提交
    • A
      Cluster: slaves start failover with a small delay. · 1375b061
      antirez 提交于
      Redis Cluster can cope with a minority of nodes not informed about the
      failure of a master in time for some reason (netsplit or node not
      functioning properly, blocked, ...) however to wait a few seconds before
      to start the failover will make most "normal" failovers simpler as the
      FAIL message will propagate before the slave election happens.
      1375b061
  25. 14 3月, 2013 2 次提交
  26. 13 3月, 2013 1 次提交
  27. 09 3月, 2013 1 次提交
  28. 08 3月, 2013 1 次提交
  29. 07 3月, 2013 1 次提交
  30. 06 3月, 2013 1 次提交
    • A
      API to lookup commands with their original name. · 7b190a08
      antirez 提交于
      A new server.orig_commands table was added to the server structure, this
      contains a copy of the commant table unaffected by rename-command
      statements in redis.conf.
      
      A new API lookupCommandOrOriginal() was added that checks both tables,
      new first, old later, so that rewriteClientCommandVector() and friends
      can lookup commands with their new or original name in order to fix the
      client->cmd pointer when the argument vector is renamed.
      
      This fixes the segfault of issue #986, but does not fix a wider range of
      problems resulting from renaming commands that actually operate on data
      and are registered into the AOF file or propagated to slaves... That is
      command renaming should be handled with care.
      7b190a08
  31. 05 3月, 2013 1 次提交
    • A
      Cluster: new node field fail_time. · 1a02b744
      antirez 提交于
      This is the unix time at which we set the FAIL flag for the node.
      It is only valid if FAIL is set.
      
      The idea is to use it in order to make the cluster more robust, for
      instance in order to revert a FAIL state if it is long-standing but
      still slots are assigned to this node, that is, no one is going to fix
      these slots apparently.
      1a02b744