Windows系统下PHP使用Redis

  在 http://www.redis.net.cn/ 能找到所有关于redis的信息,包括安装、命令、在编程语言中的使用等等。这里就不讲如何安装redis了,因为在上面的网站中都能找到。下面直接讲redis是如何在php中使用的,这里我选择的是phpredis扩展。

1. 下载phpredis扩展  

  执行phpinfo()函数,根据下面截图中的“NTS”和“VCn”选择对应的压缩包,https://github.com/phpredis/phpredis/downloads。另外注意,PHP版本也要对应好。

2. PHP配置安装扩展

  首先把压缩包中的 php_igbinary.dll和php_redis.dll 文件放到PHP安装目录的 ext 目录中

  然后在 php.ini 添加如下配置

extension=php_igbinary.dll
extension=php_redis.dll

 

3. 重启apache,执行phpinfo()函数,会发现多了redis的扩展。

 4. 开启Redis服务,测试

    $redis = new Redis();
    //连接redis服务器
    $redis->connect('127.0.0.1', '6379');
    echo "Connection to server sucessfully <br/>";

    //查看服务是否运行
    echo "Server is running: " . $redis->ping();

结果如下,连接redis服务器成功

Connection to server sucessfully 
Server is running: +PONG

至此,我们可以在php中痛痛快快的使用redis了。

 1     $redis = new Redis();
 2     //连接redis服务器
 3     $redis->connect('127.0.0.1', '6379');
 4 
 5 
 6     $key = "key";
 7     $val = "val";
 8 
 9     //redis key操作
10     $redis->exists($key);           //判断key值是否存在
11     $redis->expire($key, 10);       //设置key在10秒后过期
12 
13     //redis string 字符串
14     $redis->set($key, $val);
15     $redis->incr($key);         //key值+1,除非val是整数,否则函数执行失败
16     $redis->decr($key);         //key值-1,同上
17     $redis->append($key, "ue"); //追加key值内容
18     $redis->strlen($key);       //返回key值的长度
19 
20     //当第一次设置key值后,key值的数据类型就不能改变了。
21     $redis->del($key);  //删除key值
22 
23     //redis hash 哈希
24     $redis->hset($key, 'field1', 'val1');   //设置一个key-value键值对
25     $redis->hmset($key, array('field2'=>'val2', 'field3'=>'val3'));    //设置多个k-v键值对
26     $redis->hget($key, 'field2');           //获取hash其中的一个键值
27     $redis->hmget($key, array('field2', 'field1'));    //获取hash的多个键值
28     $redis->hgetall($key);  //获取hash中所有的键值对
29     $redis->hlen($key);     //获取hash中键值对的个数
30     $redis->hkeys($key);   //获取hash中所有的键
31     $redis->hvals($key);    //获取hash中所有的值
32     $redis->del($key);  //删除key值
33 
34     //redis list 列表
35     $index = $start = 0;
36     $redis->lpush($key, 'val1', 'val2');    //在list的开头添加多个值
37     $redis->lpop($key); //移除并获取list的第一个元素
38     $redis->rpop($key); //移除并获取list的最后一个元素
39     $stop = $redis->llen($key) - 1; //获取list的长度
40     $redis->lindex($key, $index);   //通过索引获取list元素
41     $redis->lrange($key, $start, $stop);    //获取指定范围内的元素
42 
43     $redis->del($key);
44 
45     //redis set 无序集合
46     $redis->sadd($key, 'val1', 'val2'); //向集合中添加多个元素
47     $redis->scard($key);    //获取集合元素个数
48     $redis->spop($key); //移除并获取集合内随机一个元素
49     $redis->srem($key, 'val1', 'val2'); //移除集合的多个元素
50     $redis->sismember($key, 'val1');    //判断元素是否存在于集合内
51 
52     $redis->del($key);
53     //redis sorted set 有序集合
54     //有序集合里的元素都和一个分数score关联,就靠这个分数score对元素进行排序
55     $redis->zadd($key, $score1, $val1, $score2, $val2); //向集合内添加多个元素
56     $redis->zcard($key);    //获取集合内元素总数
57     $redis->zcount($key, $minScore, $maxScore); //获取集合内分类范围内的元素
58     $redis->zrem($key, $member1, $member2); //移除集合内多个元素

附:Redis类的源码

   1 <?php
   2 /**
   3  * Helper autocomplete for php redis extension
   4  * @author Max Kamashev <max.kamashev@gmail.com>
   5  * @link https://github.com/ukko/phpredis-phpdoc
   6  *
   7  * @method echo string $string Sends a string to Redis, which replies with the same string
   8  *
   9  * @method  eval( $script, $args = array(), $numKeys = 0 )
  10  *  Evaluate a LUA script serverside
  11  *  @param  string  $script
  12  *  @param  array   $args
  13  *  @param  int     $numKeys
  14  *  @return Mixed.  What is returned depends on what the LUA script itself returns, which could be a scalar value
  15  *  (int/string), or an array. Arrays that are returned can also contain other arrays, if that's how it was set up in
  16  *  your LUA script.  If there is an error executing the LUA script, the getLastError() function can tell you the
  17  *  message that came back from Redis (e.g. compile error).
  18  *  @link   http://redis.io/commands/eval
  19  *  @example
  20  *  <pre>
  21  *  $redis->eval("return 1"); // Returns an integer: 1
  22  *  $redis->eval("return {1,2,3}"); // Returns Array(1,2,3)
  23  *  $redis->del('mylist');
  24  *  $redis->rpush('mylist','a');
  25  *  $redis->rpush('mylist','b');
  26  *  $redis->rpush('mylist','c');
  27  *  // Nested response:  Array(1,2,3,Array('a','b','c'));
  28  *  $redis->eval("return {1,2,3,redis.call('lrange','mylist',0,-1)}}");
  29  * </pre>
  30  *
  31  */
  32 class Redis
  33 {
  34     const AFTER                 = 'after';
  35     const BEFORE                = 'before';
  36 
  37     /**
  38      * Options
  39      */
  40     const OPT_SERIALIZER        = 1;
  41     const OPT_PREFIX            = 2;
  42     const OPT_READ_TIMEOUT = 3;
  43     const OPT_SCAN = 4;
  44 
  45     /**
  46      * Serializers
  47      */
  48     const SERIALIZER_NONE       = 0;
  49     const SERIALIZER_PHP        = 1;
  50     const SERIALIZER_IGBINARY   = 2;
  51 
  52     /**
  53      * Multi
  54      */
  55     const ATOMIC = 0;
  56     const MULTI = 1;
  57     const PIPELINE = 2;
  58 
  59     /**
  60      * Type
  61      */
  62     const REDIS_NOT_FOUND       = 0;
  63     const REDIS_STRING          = 1;
  64     const REDIS_SET             = 2;
  65     const REDIS_LIST            = 3;
  66     const REDIS_ZSET            = 4;
  67     const REDIS_HASH            = 5;
  68 
  69 
  70     /**
  71      * Scan
  72      */
  73      const SCAN_NORETRY = 0;
  74      const SCAN_RETRY = 1;
  75 
  76      /**
  77      * Creates a Redis client
  78      *
  79      * @example $redis = new Redis();
  80      */
  81     public function __construct( ) {}
  82 
  83     /**
  84      * Connects to a Redis instance.
  85      *
  86      * @param string    $host       can be a host, or the path to a unix domain socket
  87      * @param int       $port       optional
  88      * @param float     $timeout    value in seconds (optional, default is 0.0 meaning unlimited)
  89      * @return bool                 TRUE on success, FALSE on error.
  90      * <pre>
  91      * $redis->connect('127.0.0.1', 6379);
  92      * $redis->connect('127.0.0.1');            // port 6379 by default
  93      * $redis->connect('127.0.0.1', 6379, 2.5); // 2.5 sec timeout.
  94      * $redis->connect('/tmp/redis.sock');      // unix domain socket.
  95      * </pre>
  96      */
  97     public function connect( $host, $port = 6379, $timeout = 0.0 ) {}
  98 
  99     /**
 100      * Set the string value in argument as value of the key, with a time to live.
 101      *
 102      * @param   string $key
 103      * @param   int $ttl in milliseconds
 104      * @param   string $value
 105      * @return  bool:   TRUE if the command is successful.
 106      * @link    http://redis.io/commands/setex
 107      * $redis->psetex('key', 100, 'value'); // sets key → value, with 0.1 sec TTL.
 108      */
 109     public function psetex($key, $ttl, $value) {}
 110 
 111     /**
 112      * Scan a set for members.
 113      *
 114      * @see scan()
 115      * @param   string $key
 116      * @param   int $iterator
 117      * @param   string $pattern
 118      * @param   int $count
 119      * @return  array|bool
 120      */
 121     public function sScan($key, $iterator, $pattern = '', $count = 0) {}
 122 
 123     /**
 124      * Scan the keyspace for keys.
 125      *
 126      * @param   int $iterator
 127      * @param   string $pattern
 128      * @param   int $count How many keys to return in a go (only a sugestion to Redis)
 129      * @return  array|bool   an array of keys or FALSE if there are no more keys
 130      * @link    http://redis.io/commands/scan
 131      * <pre>
 132      * $it = NULL; // Initialize our iterator to NULL
 133      * $redis->setOption(Redis::OPT_SCAN, Redis::SCAN_RETRY); // retry when we get no keys back
 134      * while($arr_keys = $redis->scan($it)) {
 135      *   foreach($arr_keys as $str_key) {
 136      *     echo "Here is a key: $str_key
";
 137      *   }
 138      *   echo "No more keys to scan!
";
 139      * }
 140      * </pre>
 141      */
 142     public function scan($iterator, $pattern = '', $count = 0) {}
 143 
 144     /**
 145      * Scan a sorted set for members, with optional pattern and count.
 146      *
 147      * @see scan()
 148      * @param   string  $key
 149      * @param   int $iterator
 150      * @param   string  $pattern
 151      * @param   int $count
 152      * @return  array|bool
 153      */
 154     public function zScan($key, $iterator, $pattern = '', $count = 0) {}
 155 
 156     /**
 157      * Scan a HASH value for members, with an optional pattern and count.
 158      *
 159      * @see scan()
 160      * @param   string $key
 161      * @param   int $iterator
 162      * @param   string $pattern
 163      * @param   int $count
 164      * @return  array
 165      */
 166     public function hScan($key, $iterator, $pattern = '', $count = 0) {}
 167 
 168 
 169 
 170     /**
 171      * Issue the CLIENT command with various arguments.
 172      * @param   string $command list | getname | setname | kill
 173      * @param   string $arg
 174      * @return  mixed
 175      * @link    http://redis.io/commands/client-list
 176      * @link    http://redis.io/commands/client-getname
 177      * @link    http://redis.io/commands/client-setname
 178      * @link    http://redis.io/commands/client-kill
 179      * <pre>
 180      * $redis->client('list');
 181      * $redis->client('getname');
 182      * $redis->client('setname', 'somename');
 183      * $redis->client('kill', <ip:port>);
 184      * </pre>
 185      *
 186      *
 187      * CLIENT LIST will return an array of arrays with client information.
 188      * CLIENT GETNAME will return the client name or false if none has been set
 189      * CLIENT SETNAME will return true if it can be set and false if not
 190      * CLIENT KILL will return true if the client can be killed, and false if not
 191      */
 192     public function client($command, $arg = '') {}
 193 
 194     /**
 195      * Access the Redis slow log.
 196      *
 197      * @param   string $command get | len | reset
 198      * @return  mixed
 199      * @link    http://redis.io/commands/slowlog
 200      * <pre>
 201      * // Get ten slowlog entries
 202      * $redis->slowlog('get', 10);
 203      *
 204      * // Get the default number of slowlog entries
 205      * $redis->slowlog('get');
 206      *
 207      * // Reset our slowlog
 208      * $redis->slowlog('reset');
 209      *
 210      * // Retrieve slowlog length
 211      * $redis->slowlog('len');
 212      * </pre>
 213      */
 214     public function slowlog($command) {}
 215 
 216     /**
 217      * @see connect()
 218      * @param string    $host
 219      * @param int       $port
 220      * @param float     $timeout
 221      */
 222     public function open( $host, $port = 6379, $timeout = 0.0 ) {}
 223 
 224     /**
 225      * Connects to a Redis instance or reuse a connection already established with pconnect/popen.
 226      *
 227      * The connection will not be closed on close or end of request until the php process ends.
 228      * So be patient on to many open FD's (specially on redis server side) when using persistent connections on
 229      * many servers connecting to one redis server.
 230      *
 231      * Also more than one persistent connection can be made identified by either host + port + timeout
 232      * or unix socket + timeout.
 233      *
 234      * This feature is not available in threaded versions. pconnect and popen then working like their non persistent
 235      * equivalents.
 236      *
 237      * @param string    $host       can be a host, or the path to a unix domain socket
 238      * @param int       $port       optional
 239      * @param float     $timeout    value in seconds (optional, default is 0 meaning unlimited)
 240      * @return bool                 TRUE on success, FALSE on ertcnror.
 241      * <pre>
 242      * $redis->connect('127.0.0.1', 6379);
 243      * $redis->connect('127.0.0.1');            // port 6379 by default
 244      * $redis->connect('127.0.0.1', 6379, 2.5); // 2.5 sec timeout.
 245      * $redis->connect('/tmp/redis.sock');      // unix domain socket.
 246      * </pre>
 247      */
 248     public function pconnect( $host, $port = 6379, $timeout = 0.0 ) {}
 249 
 250     /**
 251      * @see pconnect()
 252      * @param string    $host
 253      * @param int       $port
 254      * @param float     $timeout
 255      */
 256     public function popen( $host, $port = 6379, $timeout = 0.0 ) {}
 257 
 258     /**
 259      * Disconnects from the Redis instance, except when pconnect is used.
 260      */
 261     public function close( ) {}
 262 
 263     /**
 264      * Set client option.
 265      *
 266      * @param   string  $name    parameter name
 267      * @param   string  $value   parameter value
 268      * @return  bool:   TRUE on success, FALSE on error.
 269      * @example
 270      * <pre>
 271      * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_NONE);        // don't serialize data
 272      * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP);         // use built-in serialize/unserialize
 273      * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_IGBINARY);    // use igBinary serialize/unserialize
 274      * $redis->setOption(Redis::OPT_PREFIX, 'myAppName:');                      // use custom prefix on all keys
 275      * </pre>
 276      */
 277     public function setOption( $name, $value ) {}
 278 
 279     /**
 280      * Get client option
 281      *
 282      * @param   string  $name parameter name
 283      * @return  int     Parameter value.
 284      * @example
 285      * // return Redis::SERIALIZER_NONE, Redis::SERIALIZER_PHP, or Redis::SERIALIZER_IGBINARY.
 286      * $redis->getOption(Redis::OPT_SERIALIZER);
 287      */
 288     public function getOption( $name ) {}
 289 
 290     /**
 291      * Check the current connection status
 292      *
 293      * @return  string STRING: +PONG on success. Throws a RedisException object on connectivity error, as described above.
 294      * @link    http://redis.io/commands/ping
 295      */
 296     public function ping( ) {}
 297 
 298     /**
 299      * Get the value related to the specified key
 300      *
 301      * @param   string  $key
 302      * @return  string|bool: If key didn't exist, FALSE is returned. Otherwise, the value related to this key is returned.
 303      * @link    http://redis.io/commands/get
 304      * @example $redis->get('key');
 305      */
 306     public function get( $key ) {}
 307 
 308 
 309     /**
 310      * Set the string value in argument as value of the key.
 311      *
 312      * @param   string  $key
 313      * @param   string  $value
 314      * @param   int   $timeout [optional] Calling setex() is preferred if you want a timeout.
 315      * @return  bool:   TRUE if the command is successful.
 316      * @link    http://redis.io/commands/set
 317      * @example $redis->set('key', 'value');
 318      */
 319     public function set( $key, $value, $timeout = 0 ) {}
 320 
 321     /**
 322      * Set the string value in argument as value of the key, with a time to live.
 323      *
 324      * @param   string  $key
 325      * @param   int     $ttl
 326      * @param   string  $value
 327      * @return  bool:   TRUE if the command is successful.
 328      * @link    http://redis.io/commands/setex
 329      * @example $redis->setex('key', 3600, 'value'); // sets key → value, with 1h TTL.
 330      */
 331     public function setex( $key, $ttl, $value ) {}
 332 
 333     /**
 334      * Set the string value in argument as value of the key if the key doesn't already exist in the database.
 335      *
 336      * @param   string  $key
 337      * @param   string  $value
 338      * @return  bool:   TRUE in case of success, FALSE in case of failure.
 339      * @link    http://redis.io/commands/setnx
 340      * @example
 341      * <pre>
 342      * $redis->setnx('key', 'value');   // return TRUE
 343      * $redis->setnx('key', 'value');   // return FALSE
 344      * </pre>
 345      */
 346     public function setnx( $key, $value ) {}
 347 
 348     /**
 349      * Remove specified keys.
 350      *
 351      * @param   int|array   $key1 An array of keys, or an undefined number of parameters, each a key: key1 key2 key3 ... keyN
 352      * @param   string      $key2 ...
 353      * @param   string      $key3 ...
 354      * @return int Number of keys deleted.
 355      * @link    http://redis.io/commands/del
 356      * @example
 357      * <pre>
 358      * $redis->set('key1', 'val1');
 359      * $redis->set('key2', 'val2');
 360      * $redis->set('key3', 'val3');
 361      * $redis->set('key4', 'val4');
 362      * $redis->delete('key1', 'key2');          // return 2
 363      * $redis->delete(array('key3', 'key4'));   // return 2
 364      * </pre>
 365      */
 366     public function del( $key1, $key2 = null, $key3 = null ) {}
 367 
 368     /**
 369      * @see del()
 370      * @param $key1
 371      * @param null $key2
 372      * @param null $key3
 373      */
 374     public function delete( $key1, $key2 = null, $key3 = null ) {}
 375 
 376     /**
 377      * Enter and exit transactional mode.
 378      *
 379      * @internal param Redis::MULTI|Redis::PIPELINE
 380      * Defaults to Redis::MULTI.
 381      * A Redis::MULTI block of commands runs as a single transaction;
 382      * a Redis::PIPELINE block is simply transmitted faster to the server, but without any guarantee of atomicity.
 383      * discard cancels a transaction.
 384      * @return Redis returns the Redis instance and enters multi-mode.
 385      * Once in multi-mode, all subsequent method calls return the same object until exec() is called.
 386      * @link    http://redis.io/commands/multi
 387      * @example
 388      * <pre>
 389      * $ret = $redis->multi()
 390      *      ->set('key1', 'val1')
 391      *      ->get('key1')
 392      *      ->set('key2', 'val2')
 393      *      ->get('key2')
 394      *      ->exec();
 395      *
 396      * //$ret == array (
 397      * //    0 => TRUE,
 398      * //    1 => 'val1',
 399      * //    2 => TRUE,
 400      * //    3 => 'val2');
 401      * </pre>
 402      */
 403     public function multi( ) {}
 404 
 405     /**
 406      * @see multi()
 407      * @link    http://redis.io/commands/exec
 408      */
 409     public function exec( ) {}
 410 
 411     /**
 412      * @see multi()
 413      * @link    http://redis.io/commands/discard
 414      */
 415     public function discard( ) {}
 416 
 417     /**
 418      * Watches a key for modifications by another client. If the key is modified between WATCH and EXEC,
 419      * the MULTI/EXEC transaction will fail (return FALSE). unwatch cancels all the watching of all keys by this client.
 420      * @param string | array $key: a list of keys
 421      * @return void
 422      * @link    http://redis.io/commands/watch
 423      * @example
 424      * <pre>
 425      * $redis->watch('x');
 426      * // long code here during the execution of which other clients could well modify `x`
 427      * $ret = $redis->multi()
 428      *          ->incr('x')
 429      *          ->exec();
 430      * // $ret = FALSE if x has been modified between the call to WATCH and the call to EXEC.
 431      * </pre>
 432      */
 433     public function watch( $key ) {}
 434 
 435     /**
 436      * @see watch()
 437      * @link    http://redis.io/commands/unwatch
 438      */
 439     public function unwatch( ) {}
 440 
 441     /**
 442      * Subscribe to channels. Warning: this function will probably change in the future.
 443      *
 444      * @param array             $channels an array of channels to subscribe to
 445      * @param string | array    $callback either a string or an array($instance, 'method_name').
 446      * The callback function receives 3 parameters: the redis instance, the channel name, and the message.
 447      * @link    http://redis.io/commands/subscribe
 448      * @example
 449      * <pre>
 450      * function f($redis, $chan, $msg) {
 451      *  switch($chan) {
 452      *      case 'chan-1':
 453      *          ...
 454      *          break;
 455      *
 456      *      case 'chan-2':
 457      *                     ...
 458      *          break;
 459      *
 460      *      case 'chan-2':
 461      *          ...
 462      *          break;
 463      *      }
 464      * }
 465      *
 466      * $redis->subscribe(array('chan-1', 'chan-2', 'chan-3'), 'f'); // subscribe to 3 chans
 467      * </pre>
 468      */
 469     public function subscribe( $channels, $callback ) {}
 470 
 471     /**
 472      * Subscribe to channels by pattern
 473      *
 474      * @param   array           $patterns   The number of elements removed from the set.
 475      * @param   string|array    $callback   Either a string or an array with an object and method.
 476      *                          The callback will get four arguments ($redis, $pattern, $channel, $message)
 477      * @link    http://redis.io/commands/psubscribe
 478      * @example
 479      * <pre>
 480      * function psubscribe($redis, $pattern, $chan, $msg) {
 481      *  echo "Pattern: $pattern
";
 482      *  echo "Channel: $chan
";
 483      *  echo "Payload: $msg
";
 484      * }
 485      * </pre>
 486      */
 487     public function psubscribe( $patterns, $callback ) {}
 488 
 489     /**
 490      * Publish messages to channels. Warning: this function will probably change in the future.
 491      *
 492      * @param   string $channel a channel to publish to
 493      * @param   string $message string
 494      * @link    http://redis.io/commands/publish
 495      * @return  int Number of clients that received the message
 496      * @example $redis->publish('chan-1', 'hello, world!'); // send message.
 497      */
 498     public function publish( $channel, $message ) {}
 499 
 500     /**
 501      * Verify if the specified key exists.
 502      *
 503      * @param   string $key
 504      * @return  bool: If the key exists, return TRUE, otherwise return FALSE.
 505      * @link    http://redis.io/commands/exists
 506      * @example
 507      * <pre>
 508      * $redis->set('key', 'value');
 509      * $redis->exists('key');               //  TRUE
 510      * $redis->exists('NonExistingKey');    // FALSE
 511      * </pre>
 512      */
 513     public function exists( $key ) {}
 514 
 515     /**
 516      * Increment the number stored at key by one.
 517      *
 518      * @param   string $key
 519      * @return  int    the new value
 520      * @link    http://redis.io/commands/incr
 521      * @example
 522      * <pre>
 523      * $redis->incr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value 1
 524      * $redis->incr('key1'); // 2
 525      * $redis->incr('key1'); // 3
 526      * $redis->incr('key1'); // 4
 527      * </pre>
 528      */
 529     public function incr( $key ) {}
 530 
 531     /**
 532      * Increment the float value of a key by the given amount
 533      *
 534      * @param   string  $key
 535      * @param   float   $increment
 536      * @return  float
 537      * @link    http://redis.io/commands/incrbyfloat
 538      * @example
 539      * <pre>
 540      * $redis = new Redis();
 541      * $redis->connect('127.0.0.1');
 542      * $redis->set('x', 3);
 543      * var_dump( $redis->incrByFloat('x', 1.5) );   // float(4.5)
 544      *
 545      * // ! SIC
 546      * var_dump( $redis->get('x') );                // string(3) "4.5"
 547      * </pre>
 548      */
 549     public function incrByFloat( $key, $increment ) {}
 550 
 551     /**
 552      * Increment the number stored at key by one. If the second argument is filled, it will be used as the integer
 553      * value of the increment.
 554      *
 555      * @param   string    $key    key
 556      * @param   int       $value  value that will be added to key (only for incrBy)
 557      * @return  int         the new value
 558      * @link    http://redis.io/commands/incrby
 559      * @example
 560      * <pre>
 561      * $redis->incr('key1');        // key1 didn't exists, set to 0 before the increment and now has the value 1
 562      * $redis->incr('key1');        // 2
 563      * $redis->incr('key1');        // 3
 564      * $redis->incr('key1');        // 4
 565      * $redis->incrBy('key1', 10);  // 14
 566      * </pre>
 567      */
 568     public function incrBy( $key, $value ) {}
 569 
 570     /**
 571      * Decrement the number stored at key by one.
 572      *
 573      * @param   string $key
 574      * @return  int    the new value
 575      * @link    http://redis.io/commands/decr
 576      * @example
 577      * <pre>
 578      * $redis->decr('key1'); // key1 didn't exists, set to 0 before the increment and now has the value -1
 579      * $redis->decr('key1'); // -2
 580      * $redis->decr('key1'); // -3
 581      * </pre>
 582      */
 583     public function decr( $key ) {}
 584 
 585     /**
 586      * Decrement the number stored at key by one. If the second argument is filled, it will be used as the integer
 587      * value of the decrement.
 588      *
 589      * @param   string    $key
 590      * @param   int       $value  that will be substracted to key (only for decrBy)
 591      * @return  int       the new value
 592      * @link    http://redis.io/commands/decrby
 593      * @example
 594      * <pre>
 595      * $redis->decr('key1');        // key1 didn't exists, set to 0 before the increment and now has the value -1
 596      * $redis->decr('key1');        // -2
 597      * $redis->decr('key1');        // -3
 598      * $redis->decrBy('key1', 10);  // -13
 599      * </pre>
 600      */
 601     public function decrBy( $key, $value ) {}
 602 
 603     /**
 604      * Get the values of all the specified keys. If one or more keys dont exist, the array will contain FALSE at the
 605      * position of the key.
 606      *
 607      * @param   array $keys Array containing the list of the keys
 608      * @return  array Array containing the values related to keys in argument
 609      * @example
 610      * <pre>
 611      * $redis->set('key1', 'value1');
 612      * $redis->set('key2', 'value2');
 613      * $redis->set('key3', 'value3');
 614      * $redis->getMultiple(array('key1', 'key2', 'key3')); // array('value1', 'value2', 'value3');
 615      * $redis->getMultiple(array('key0', 'key1', 'key5')); // array(`FALSE`, 'value2', `FALSE`);
 616      * </pre>
 617      */
 618     public function getMultiple( array $keys ) {}
 619 
 620     /**
 621      * Adds the string values to the head (left) of the list. Creates the list if the key didn't exist.
 622      * If the key exists and is not a list, FALSE is returned.
 623      *
 624      * @param   string $key
 625      * @param   string $value1  String, value to push in key
 626      * @param   string $value2  Optional
 627      * @param   string $valueN  Optional
 628      * @return  int    The new length of the list in case of success, FALSE in case of Failure.
 629      * @link    http://redis.io/commands/lpush
 630      * @example
 631      * <pre>
 632      * $redis->lPush('l', 'v1', 'v2', 'v3', 'v4')   // int(4)
 633      * var_dump( $redis->lRange('l', 0, -1) );
 634      * //// Output:
 635      * // array(4) {
 636      * //   [0]=> string(2) "v4"
 637      * //   [1]=> string(2) "v3"
 638      * //   [2]=> string(2) "v2"
 639      * //   [3]=> string(2) "v1"
 640      * // }
 641      * </pre>
 642      */
 643     public function lPush( $key, $value1, $value2 = null, $valueN = null ) {}
 644 
 645     /**
 646      * Adds the string values to the tail (right) of the list. Creates the list if the key didn't exist.
 647      * If the key exists and is not a list, FALSE is returned.
 648      *
 649      * @param   string  $key
 650      * @param   string  $value1 String, value to push in key
 651      * @param   string  $value2 Optional
 652      * @param   string  $valueN Optional
 653      * @return  int     The new length of the list in case of success, FALSE in case of Failure.
 654      * @link    http://redis.io/commands/rpush
 655      * @example
 656      * <pre>
 657      * $redis->rPush('l', 'v1', 'v2', 'v3', 'v4');    // int(4)
 658      * var_dump( $redis->lRange('l', 0, -1) );
 659      * //// Output:
 660      * // array(4) {
 661      * //   [0]=> string(2) "v1"
 662      * //   [1]=> string(2) "v2"
 663      * //   [2]=> string(2) "v3"
 664      * //   [3]=> string(2) "v4"
 665      * // }
 666      * </pre>
 667      */
 668     public function rPush( $key, $value1, $value2 = null, $valueN = null ) {}
 669 
 670     /**
 671      * Adds the string value to the head (left) of the list if the list exists.
 672      *
 673      * @param   string  $key
 674      * @param   string  $value String, value to push in key
 675      * @return  int     The new length of the list in case of success, FALSE in case of Failure.
 676      * @link    http://redis.io/commands/lpushx
 677      * @example
 678      * <pre>
 679      * $redis->delete('key1');
 680      * $redis->lPushx('key1', 'A');     // returns 0
 681      * $redis->lPush('key1', 'A');      // returns 1
 682      * $redis->lPushx('key1', 'B');     // returns 2
 683      * $redis->lPushx('key1', 'C');     // returns 3
 684      * // key1 now points to the following list: [ 'A', 'B', 'C' ]
 685      * </pre>
 686      */
 687     public function lPushx( $key, $value ) {}
 688 
 689     /**
 690      * Adds the string value to the tail (right) of the list if the ist exists. FALSE in case of Failure.
 691      *
 692      * @param   string  $key
 693      * @param   string  $value String, value to push in key
 694      * @return  int     The new length of the list in case of success, FALSE in case of Failure.
 695      * @link    http://redis.io/commands/rpushx
 696      * @example
 697      * <pre>
 698      * $redis->delete('key1');
 699      * $redis->rPushx('key1', 'A'); // returns 0
 700      * $redis->rPush('key1', 'A'); // returns 1
 701      * $redis->rPushx('key1', 'B'); // returns 2
 702      * $redis->rPushx('key1', 'C'); // returns 3
 703      * // key1 now points to the following list: [ 'A', 'B', 'C' ]
 704      * </pre>
 705      */
 706     public function rPushx( $key, $value ) {}
 707 
 708     /**
 709      * Returns and removes the first element of the list.
 710      *
 711      * @param   string $key
 712      * @return  string if command executed successfully BOOL FALSE in case of failure (empty list)
 713      * @link    http://redis.io/commands/lpop
 714      * @example
 715      * <pre>
 716      * $redis->rPush('key1', 'A');
 717      * $redis->rPush('key1', 'B');
 718      * $redis->rPush('key1', 'C');  // key1 => [ 'A', 'B', 'C' ]
 719      * $redis->lPop('key1');        // key1 => [ 'B', 'C' ]
 720      * </pre>
 721      */
 722     public function lPop( $key ) {}
 723 
 724     /**
 725      * Returns and removes the last element of the list.
 726      *
 727      * @param   string $key
 728      * @return  string if command executed successfully BOOL FALSE in case of failure (empty list)
 729      * @link    http://redis.io/commands/rpop
 730      * @example
 731      * <pre>
 732      * $redis->rPush('key1', 'A');
 733      * $redis->rPush('key1', 'B');
 734      * $redis->rPush('key1', 'C');  // key1 => [ 'A', 'B', 'C' ]
 735      * $redis->rPop('key1');        // key1 => [ 'A', 'B' ]
 736      * </pre>
 737      */
 738     public function rPop( $key ) {}
 739 
 740     /**
 741      * Is a blocking lPop primitive. If at least one of the lists contains at least one element,
 742      * the element will be popped from the head of the list and returned to the caller.
 743      * Il all the list identified by the keys passed in arguments are empty, blPop will block
 744      * during the specified timeout until an element is pushed to one of those lists. This element will be popped.
 745      *
 746      * @param   array $keys Array containing the keys of the lists INTEGER Timeout
 747      * Or STRING Key1 STRING Key2 STRING Key3 ... STRING Keyn INTEGER Timeout
 748      * @return  array array('listName', 'element')
 749      * @link    http://redis.io/commands/blpop
 750      * @example
 751      * <pre>
 752      * // Non blocking feature
 753      * $redis->lPush('key1', 'A');
 754      * $redis->delete('key2');
 755      *
 756      * $redis->blPop('key1', 'key2', 10); // array('key1', 'A')
 757      * // OR
 758      * $redis->blPop(array('key1', 'key2'), 10); // array('key1', 'A')
 759      *
 760      * $redis->brPop('key1', 'key2', 10); // array('key1', 'A')
 761      * // OR
 762      * $redis->brPop(array('key1', 'key2'), 10); // array('key1', 'A')
 763      *
 764      * // Blocking feature
 765      *
 766      * // process 1
 767      * $redis->delete('key1');
 768      * $redis->blPop('key1', 10);
 769      * // blocking for 10 seconds
 770      *
 771      * // process 2
 772      * $redis->lPush('key1', 'A');
 773      *
 774      * // process 1
 775      * // array('key1', 'A') is returned
 776      * </pre>
 777      */
 778     public function blPop( array $keys ) {}
 779 
 780     /**
 781      * Is a blocking rPop primitive. If at least one of the lists contains at least one element,
 782      * the element will be popped from the head of the list and returned to the caller.
 783      * Il all the list identified by the keys passed in arguments are empty, brPop will
 784      * block during the specified timeout until an element is pushed to one of those lists. T
 785      * his element will be popped.
 786      *
 787      * @param   array $keys Array containing the keys of the lists INTEGER Timeout
 788      * Or STRING Key1 STRING Key2 STRING Key3 ... STRING Keyn INTEGER Timeout
 789      * @return  array array('listName', 'element')
 790      * @link    http://redis.io/commands/brpop
 791      * @example
 792      * <pre>
 793      * // Non blocking feature
 794      * $redis->lPush('key1', 'A');
 795      * $redis->delete('key2');
 796      *
 797      * $redis->blPop('key1', 'key2', 10); // array('key1', 'A')
 798      * // OR
 799      * $redis->blPop(array('key1', 'key2'), 10); // array('key1', 'A')
 800      *
 801      * $redis->brPop('key1', 'key2', 10); // array('key1', 'A')
 802      * // OR
 803      * $redis->brPop(array('key1', 'key2'), 10); // array('key1', 'A')
 804      *
 805      * // Blocking feature
 806      *
 807      * // process 1
 808      * $redis->delete('key1');
 809      * $redis->blPop('key1', 10);
 810      * // blocking for 10 seconds
 811      *
 812      * // process 2
 813      * $redis->lPush('key1', 'A');
 814      *
 815      * // process 1
 816      * // array('key1', 'A') is returned
 817      * </pre>
 818      */
 819     public function brPop( array $keys ) {}
 820 
 821 
 822     /**
 823      * Returns the size of a list identified by Key. If the list didn't exist or is empty,
 824      * the command returns 0. If the data type identified by Key is not a list, the command return FALSE.
 825      *
 826      * @param   string  $key
 827      * @return  int     The size of the list identified by Key exists.
 828      * bool FALSE if the data type identified by Key is not list
 829      * @link    http://redis.io/commands/llen
 830      * @example
 831      * <pre>
 832      * $redis->rPush('key1', 'A');
 833      * $redis->rPush('key1', 'B');
 834      * $redis->rPush('key1', 'C');  // key1 => [ 'A', 'B', 'C' ]
 835      * $redis->lLen('key1');       // 3
 836      * $redis->rPop('key1');
 837      * $redis->lLen('key1');       // 2
 838      * </pre>
 839      */
 840     public function lLen( $key ) {}
 841 
 842     /**
 843      * @see     lLen()
 844      * @param   string    $key
 845      * @param   int       $index
 846      * @link    http://redis.io/commands/llen
 847      */
 848     public function lSize( $key ) {}
 849 
 850 
 851     /**
 852      * Return the specified element of the list stored at the specified key.
 853      * 0 the first element, 1 the second ... -1 the last element, -2 the penultimate ...
 854      * Return FALSE in case of a bad index or a key that doesn't point to a list.
 855      * @param string    $key
 856      * @param int       $index
 857      * @return String the element at this index
 858      * Bool FALSE if the key identifies a non-string data type, or no value corresponds to this index in the list Key.
 859      * @link    http://redis.io/commands/lindex
 860      * @example
 861      * <pre>
 862      * $redis->rPush('key1', 'A');
 863      * $redis->rPush('key1', 'B');
 864      * $redis->rPush('key1', 'C');  // key1 => [ 'A', 'B', 'C' ]
 865      * $redis->lGet('key1', 0);     // 'A'
 866      * $redis->lGet('key1', -1);    // 'C'
 867      * $redis->lGet('key1', 10);    // `FALSE`
 868      * </pre>
 869      */
 870     public function lIndex( $key, $index ) {}
 871 
 872     /**
 873      * @see lIndex()
 874      * @param   string    $key
 875      * @param   int       $index
 876      * @link    http://redis.io/commands/lindex
 877      */
 878     public function lGet( $key, $index ) {}
 879 
 880 
 881     /**
 882      * Set the list at index with the new value.
 883      *
 884      * @param string    $key
 885      * @param int       $index
 886      * @param string    $value
 887      * @return BOOL TRUE if the new value is setted. FALSE if the index is out of range, or data type identified by key
 888      * is not a list.
 889      * @link    http://redis.io/commands/lset
 890      * @example
 891      * <pre>
 892      * $redis->rPush('key1', 'A');
 893      * $redis->rPush('key1', 'B');
 894      * $redis->rPush('key1', 'C');  // key1 => [ 'A', 'B', 'C' ]
 895      * $redis->lGet('key1', 0);     // 'A'
 896      * $redis->lSet('key1', 0, 'X');
 897      * $redis->lGet('key1', 0);     // 'X'
 898      * </pre>
 899      */
 900     public function lSet( $key, $index, $value ) {}
 901 
 902 
 903     /**
 904      * Returns the specified elements of the list stored at the specified key in
 905      * the range [start, end]. start and stop are interpretated as indices: 0 the first element,
 906      * 1 the second ... -1 the last element, -2 the penultimate ...
 907      * @param   string  $key
 908      * @param   int     $start
 909      * @param   int     $end
 910      * @return  array containing the values in specified range.
 911      * @link    http://redis.io/commands/lrange
 912      * @example
 913      * <pre>
 914      * $redis->rPush('key1', 'A');
 915      * $redis->rPush('key1', 'B');
 916      * $redis->rPush('key1', 'C');
 917      * $redis->lRange('key1', 0, -1); // array('A', 'B', 'C')
 918      * </pre>
 919      */
 920     public function lRange( $key, $start, $end ) {}
 921 
 922     /**
 923      * @see lRange()
 924      * @link http://redis.io/commands/lrange
 925      * @param string    $key
 926      * @param int       $start
 927      * @param int       $end
 928      */
 929     public function lGetRange( $key, $start, $end ) {}
 930 
 931 
 932     /**
 933      * Trims an existing list so that it will contain only a specified range of elements.
 934      *
 935      * @param string    $key
 936      * @param int       $start
 937      * @param int       $stop
 938      * @return array    Bool return FALSE if the key identify a non-list value.
 939      * @link        http://redis.io/commands/ltrim
 940      * @example
 941      * <pre>
 942      * $redis->rPush('key1', 'A');
 943      * $redis->rPush('key1', 'B');
 944      * $redis->rPush('key1', 'C');
 945      * $redis->lRange('key1', 0, -1); // array('A', 'B', 'C')
 946      * $redis->lTrim('key1', 0, 1);
 947      * $redis->lRange('key1', 0, -1); // array('A', 'B')
 948      * </pre>
 949      */
 950     public function lTrim( $key, $start, $stop ) {}
 951 
 952     /**
 953      * @see lTrim()
 954      * @link  http://redis.io/commands/ltrim
 955      * @param string    $key
 956      * @param int       $start
 957      * @param int       $stop
 958      */
 959     public function listTrim( $key, $start, $stop ) {}
 960 
 961 
 962     /**
 963      * Removes the first count occurences of the value element from the list.
 964      * If count is zero, all the matching elements are removed. If count is negative,
 965      * elements are removed from tail to head.
 966      *
 967      * @param   string  $key
 968      * @param   string  $value
 969      * @param   int     $count
 970      * @return  int     the number of elements to remove
 971      * bool FALSE if the value identified by key is not a list.
 972      * @link    http://redis.io/commands/lrem
 973      * @example
 974      * <pre>
 975      * $redis->lPush('key1', 'A');
 976      * $redis->lPush('key1', 'B');
 977      * $redis->lPush('key1', 'C');
 978      * $redis->lPush('key1', 'A');
 979      * $redis->lPush('key1', 'A');
 980      *
 981      * $redis->lRange('key1', 0, -1);   // array('A', 'A', 'C', 'B', 'A')
 982      * $redis->lRem('key1', 'A', 2);    // 2
 983      * $redis->lRange('key1', 0, -1);   // array('C', 'B', 'A')
 984      * </pre>
 985      */
 986     public function lRem( $key, $value, $count ) {}
 987 
 988     /**
 989      * @see lRem
 990      * @link    http://redis.io/commands/lremove
 991      * @param string    $key
 992      * @param string    $value
 993      * @param int       $count
 994      */
 995     public function lRemove( $key, $value, $count ) {}
 996 
 997 
 998     /**
 999      * Insert value in the list before or after the pivot value. the parameter options
1000      * specify the position of the insert (before or after). If the list didn't exists,
1001      * or the pivot didn't exists, the value is not inserted.
1002      *
1003      * @param   string  $key
1004      * @param   int     $position Redis::BEFORE | Redis::AFTER
1005      * @param   string  $pivot
1006      * @param   string  $value
1007      * @return  int     The number of the elements in the list, -1 if the pivot didn't exists.
1008      * @link    http://redis.io/commands/linsert
1009      * @example
1010      * <pre>
1011      * $redis->delete('key1');
1012      * $redis->lInsert('key1', Redis::AFTER, 'A', 'X');     // 0
1013      *
1014      * $redis->lPush('key1', 'A');
1015      * $redis->lPush('key1', 'B');
1016      * $redis->lPush('key1', 'C');
1017      *
1018      * $redis->lInsert('key1', Redis::BEFORE, 'C', 'X');    // 4
1019      * $redis->lRange('key1', 0, -1);                       // array('A', 'B', 'X', 'C')
1020      *
1021      * $redis->lInsert('key1', Redis::AFTER, 'C', 'Y');     // 5
1022      * $redis->lRange('key1', 0, -1);                       // array('A', 'B', 'X', 'C', 'Y')
1023      *
1024      * $redis->lInsert('key1', Redis::AFTER, 'W', 'value'); // -1
1025      * </pre>
1026      */
1027     public function lInsert( $key, $position, $pivot, $value ) {}
1028 
1029 
1030     /**
1031      * Adds a values to the set value stored at key.
1032      * If this value is already in the set, FALSE is returned.
1033      *
1034      * @param   string  $key        Required key
1035      * @param   string  $value1     Required value
1036      * @param   string  $value2     Optional value
1037      * @param   string  $valueN     Optional value
1038      * @return  int     The number of elements added to the set
1039      * @link    http://redis.io/commands/sadd
1040      * @example
1041      * <pre>
1042      * $redis->sAdd('k', 'v1');                // int(1)
1043      * $redis->sAdd('k', 'v1', 'v2', 'v3');    // int(2)
1044      * </pre>
1045      */
1046     public function sAdd( $key, $value1, $value2 = null, $valueN = null ) {}
1047 
1048 
1049     /**
1050      * Removes the specified members from the set value stored at key.
1051      *
1052      * @param   string  $key
1053      * @param   string  $member1
1054      * @param   string  $member2
1055      * @param   string  $memberN
1056      * @return  int     The number of elements removed from the set.
1057      * @link    http://redis.io/commands/srem
1058      * @example
1059      * <pre>
1060      * var_dump( $redis->sAdd('k', 'v1', 'v2', 'v3') );    // int(3)
1061      * var_dump( $redis->sRem('k', 'v2', 'v3') );          // int(2)
1062      * var_dump( $redis->sMembers('k') );
1063      * //// Output:
1064      * // array(1) {
1065      * //   [0]=> string(2) "v1"
1066      * // }
1067      * </pre>
1068      */
1069     public function sRem( $key, $member1, $member2 = null, $memberN = null ) {}
1070 
1071     /**
1072      * @see sRem()
1073      * @link    http://redis.io/commands/srem
1074      * @param   string  $key
1075      * @param   string  $member1
1076      * @param   string  $member2
1077      * @param   string  $memberN
1078      */
1079     public function sRemove( $key, $member1, $member2 = null, $memberN = null ) {}
1080 
1081 
1082     /**
1083      * Moves the specified member from the set at srcKey to the set at dstKey.
1084      *
1085      * @param   string  $srcKey
1086      * @param   string  $dstKey
1087      * @param   string  $member
1088      * @return  bool    If the operation is successful, return TRUE.
1089      * If the srcKey and/or dstKey didn't exist, and/or the member didn't exist in srcKey, FALSE is returned.
1090      * @link    http://redis.io/commands/smove
1091      * @example
1092      * <pre>
1093      * $redis->sAdd('key1' , 'set11');
1094      * $redis->sAdd('key1' , 'set12');
1095      * $redis->sAdd('key1' , 'set13');          // 'key1' => {'set11', 'set12', 'set13'}
1096      * $redis->sAdd('key2' , 'set21');
1097      * $redis->sAdd('key2' , 'set22');          // 'key2' => {'set21', 'set22'}
1098      * $redis->sMove('key1', 'key2', 'set13');  // 'key1' =>  {'set11', 'set12'}
1099      *                                          // 'key2' =>  {'set21', 'set22', 'set13'}
1100      * </pre>
1101      */
1102     public function sMove( $srcKey, $dstKey, $member ) {}
1103 
1104 
1105     /**
1106      * Checks if value is a member of the set stored at the key key.
1107      *
1108      * @param   string  $key
1109      * @param   string  $value
1110      * @return  bool    TRUE if value is a member of the set at key key, FALSE otherwise.
1111      * @link    http://redis.io/commands/sismember
1112      * @example
1113      * <pre>
1114      * $redis->sAdd('key1' , 'set1');
1115      * $redis->sAdd('key1' , 'set2');
1116      * $redis->sAdd('key1' , 'set3'); // 'key1' => {'set1', 'set2', 'set3'}
1117      *
1118      * $redis->sIsMember('key1', 'set1'); // TRUE
1119      * $redis->sIsMember('key1', 'setX'); // FALSE
1120      * </pre>
1121      */
1122     public function sIsMember( $key, $value ) {}
1123 
1124     /**
1125      * @see sIsMember()
1126      * @link    http://redis.io/commands/sismember
1127      * @param   string  $key
1128      * @param   string  $value
1129      */
1130     public function sContains( $key, $value ) {}
1131 
1132     /**
1133      * Returns the cardinality of the set identified by key.
1134      *
1135      * @param   string  $key
1136      * @return  int     the cardinality of the set identified by key, 0 if the set doesn't exist.
1137      * @link    http://redis.io/commands/scard
1138      * @example
1139      * <pre>
1140      * $redis->sAdd('key1' , 'set1');
1141      * $redis->sAdd('key1' , 'set2');
1142      * $redis->sAdd('key1' , 'set3');   // 'key1' => {'set1', 'set2', 'set3'}
1143      * $redis->sCard('key1');           // 3
1144      * $redis->sCard('keyX');           // 0
1145      * </pre>
1146      */
1147     public function sCard( $key ) {}
1148 
1149 
1150     /**
1151      * Removes and returns a random element from the set value at Key.
1152      *
1153      * @param   string  $key
1154      * @return  string  "popped" value
1155      * bool FALSE if set identified by key is empty or doesn't exist.
1156      * @link    http://redis.io/commands/spop
1157      * @example
1158      * <pre>
1159      * $redis->sAdd('key1' , 'set1');
1160      * $redis->sAdd('key1' , 'set2');
1161      * $redis->sAdd('key1' , 'set3');   // 'key1' => {'set3', 'set1', 'set2'}
1162      * $redis->sPop('key1');            // 'set1', 'key1' => {'set3', 'set2'}
1163      * $redis->sPop('key1');            // 'set3', 'key1' => {'set2'}
1164      * </pre>
1165      */
1166     public function sPop( $key ) {}
1167 
1168 
1169     /**
1170      * Returns a random element from the set value at Key, without removing it.
1171      *
1172      * @param   string  $key
1173      * @return  string  value from the set
1174      * bool FALSE if set identified by key is empty or doesn't exist.
1175      * @link    http://redis.io/commands/srandmember
1176      * @example
1177      * <pre>
1178      * $redis->sAdd('key1' , 'set1');
1179      * $redis->sAdd('key1' , 'set2');
1180      * $redis->sAdd('key1' , 'set3');   // 'key1' => {'set3', 'set1', 'set2'}
1181      * $redis->sRandMember('key1');     // 'set1', 'key1' => {'set3', 'set1', 'set2'}
1182      * $redis->sRandMember('key1');     // 'set3', 'key1' => {'set3', 'set1', 'set2'}
1183      * </pre>
1184      */
1185     public function sRandMember( $key ) {}
1186 
1187     /**
1188      * Returns the members of a set resulting from the intersection of all the sets
1189      * held at the specified keys. If just a single key is specified, then this command
1190      * produces the members of this set. If one of the keys is missing, FALSE is returned.
1191      *
1192      * @param   string  $key1  keys identifying the different sets on which we will apply the intersection.
1193      * @param   string  $key2  ...
1194      * @param   string  $keyN  ...
1195      * @return  array, contain the result of the intersection between those keys.
1196      * If the intersection between the different sets is empty, the return value will be empty array.
1197      * @link    http://redis.io/commands/sinterstore
1198      * @example
1199      * <pre>
1200      * $redis->sAdd('key1', 'val1');
1201      * $redis->sAdd('key1', 'val2');
1202      * $redis->sAdd('key1', 'val3');
1203      * $redis->sAdd('key1', 'val4');
1204      *
1205      * $redis->sAdd('key2', 'val3');
1206      * $redis->sAdd('key2', 'val4');
1207      *
1208      * $redis->sAdd('key3', 'val3');
1209      * $redis->sAdd('key3', 'val4');
1210      *
1211      * var_dump($redis->sInter('key1', 'key2', 'key3'));
1212      *
1213      * //array(2) {
1214      * //  [0]=>
1215      * //  string(4) "val4"
1216      * //  [1]=>
1217      * //  string(4) "val3"
1218      * //}
1219      * </pre>
1220      */
1221     public function sInter( $key1, $key2, $keyN = null ) {}
1222 
1223     /**
1224      * Performs a sInter command and stores the result in a new set.
1225      *
1226      * @param   string  $dstKey the key to store the diff into.
1227      * @param   string  $key1 are intersected as in sInter.
1228      * @param   string  $key2 ...
1229      * @param   string  $keyN ...
1230      * @return  int:    The cardinality of the resulting set, or FALSE in case of a missing key.
1231      * @link    http://redis.io/commands/sinterstore
1232      * @example
1233      * <pre>
1234      * $redis->sAdd('key1', 'val1');
1235      * $redis->sAdd('key1', 'val2');
1236      * $redis->sAdd('key1', 'val3');
1237      * $redis->sAdd('key1', 'val4');
1238      *
1239      * $redis->sAdd('key2', 'val3');
1240      * $redis->sAdd('key2', 'val4');
1241      *
1242      * $redis->sAdd('key3', 'val3');
1243      * $redis->sAdd('key3', 'val4');
1244      *
1245      * var_dump($redis->sInterStore('output', 'key1', 'key2', 'key3'));
1246      * var_dump($redis->sMembers('output'));
1247      *
1248      * //int(2)
1249      * //
1250      * //array(2) {
1251      * //  [0]=>
1252      * //  string(4) "val4"
1253      * //  [1]=>
1254      * //  string(4) "val3"
1255      * //}
1256      * </pre>
1257      */
1258     public function sInterStore( $dstKey, $key1, $key2, $keyN = null ) {}
1259 
1260     /**
1261      * Performs the union between N sets and returns it.
1262      *
1263      * @param   string  $key1 Any number of keys corresponding to sets in redis.
1264      * @param   string  $key2 ...
1265      * @param   string  $keyN ...
1266      * @return  array   of strings: The union of all these sets.
1267      * @link    http://redis.io/commands/sunionstore
1268      * @example
1269      * <pre>
1270      * $redis->delete('s0', 's1', 's2');
1271      *
1272      * $redis->sAdd('s0', '1');
1273      * $redis->sAdd('s0', '2');
1274      * $redis->sAdd('s1', '3');
1275      * $redis->sAdd('s1', '1');
1276      * $redis->sAdd('s2', '3');
1277      * $redis->sAdd('s2', '4');
1278      *
1279      * var_dump($redis->sUnion('s0', 's1', 's2'));
1280      *
1281      * array(4) {
1282      * //  [0]=>
1283      * //  string(1) "3"
1284      * //  [1]=>
1285      * //  string(1) "4"
1286      * //  [2]=>
1287      * //  string(1) "1"
1288      * //  [3]=>
1289      * //  string(1) "2"
1290      * //}
1291      * </pre>
1292      */
1293     public function sUnion( $key1, $key2, $keyN = null ) {}
1294 
1295     /**
1296      * Performs the same action as sUnion, but stores the result in the first key
1297      *
1298      * @param   string  $dstKey  the key to store the diff into.
1299      * @param   string  $key1    Any number of keys corresponding to sets in redis.
1300      * @param   string  $key2    ...
1301      * @param   string  $keyN    ...
1302      * @return  int     Any number of keys corresponding to sets in redis.
1303      * @link    http://redis.io/commands/sunionstore
1304      * @example
1305      * <pre>
1306      * $redis->delete('s0', 's1', 's2');
1307      *
1308      * $redis->sAdd('s0', '1');
1309      * $redis->sAdd('s0', '2');
1310      * $redis->sAdd('s1', '3');
1311      * $redis->sAdd('s1', '1');
1312      * $redis->sAdd('s2', '3');
1313      * $redis->sAdd('s2', '4');
1314      *
1315      * var_dump($redis->sUnionStore('dst', 's0', 's1', 's2'));
1316      * var_dump($redis->sMembers('dst'));
1317      *
1318      * //int(4)
1319      * //array(4) {
1320      * //  [0]=>
1321      * //  string(1) "3"
1322      * //  [1]=>
1323      * //  string(1) "4"
1324      * //  [2]=>
1325      * //  string(1) "1"
1326      * //  [3]=>
1327      * //  string(1) "2"
1328      * //}
1329      * </pre>
1330      */
1331     public function sUnionStore( $dstKey, $key1, $key2, $keyN = null ) {}
1332 
1333     /**
1334      * Performs the difference between N sets and returns it.
1335      *
1336      * @param   string  $key1 Any number of keys corresponding to sets in redis.
1337      * @param   string  $key2 ...
1338      * @param   string  $keyN ...
1339      * @return  array   of strings: The difference of the first set will all the others.
1340      * @link    http://redis.io/commands/sdiff
1341      * @example
1342      * <pre>
1343      * $redis->delete('s0', 's1', 's2');
1344      *
1345      * $redis->sAdd('s0', '1');
1346      * $redis->sAdd('s0', '2');
1347      * $redis->sAdd('s0', '3');
1348      * $redis->sAdd('s0', '4');
1349      *
1350      * $redis->sAdd('s1', '1');
1351      * $redis->sAdd('s2', '3');
1352      *
1353      * var_dump($redis->sDiff('s0', 's1', 's2'));
1354      *
1355      * //array(2) {
1356      * //  [0]=>
1357      * //  string(1) "4"
1358      * //  [1]=>
1359      * //  string(1) "2"
1360      * //}
1361      * </pre>
1362      */
1363     public function sDiff( $key1, $key2, $keyN = null ) {}
1364 
1365     /**
1366      * Performs the same action as sDiff, but stores the result in the first key
1367      *
1368      * @param   string  $dstKey    the key to store the diff into.
1369      * @param   string  $key1      Any number of keys corresponding to sets in redis
1370      * @param   string  $key2      ...
1371      * @param   string  $keyN      ...
1372      * @return  int:    The cardinality of the resulting set, or FALSE in case of a missing key.
1373      * @link    http://redis.io/commands/sdiffstore
1374      * @example
1375      * <pre>
1376      * $redis->delete('s0', 's1', 's2');
1377      *
1378      * $redis->sAdd('s0', '1');
1379      * $redis->sAdd('s0', '2');
1380      * $redis->sAdd('s0', '3');
1381      * $redis->sAdd('s0', '4');
1382      *
1383      * $redis->sAdd('s1', '1');
1384      * $redis->sAdd('s2', '3');
1385      *
1386      * var_dump($redis->sDiffStore('dst', 's0', 's1', 's2'));
1387      * var_dump($redis->sMembers('dst'));
1388      *
1389      * //int(2)
1390      * //array(2) {
1391      * //  [0]=>
1392      * //  string(1) "4"
1393      * //  [1]=>
1394      * //  string(1) "2"
1395      * //}
1396      * </pre>
1397      */
1398     public function sDiffStore( $dstKey, $key1, $key2, $keyN = null ) {}
1399 
1400     /**
1401      * Returns the contents of a set.
1402      *
1403      * @param   string  $key
1404      * @return  array   An array of elements, the contents of the set.
1405      * @link    http://redis.io/commands/smembers
1406      * @example
1407      * <pre>
1408      * $redis->delete('s');
1409      * $redis->sAdd('s', 'a');
1410      * $redis->sAdd('s', 'b');
1411      * $redis->sAdd('s', 'a');
1412      * $redis->sAdd('s', 'c');
1413      * var_dump($redis->sMembers('s'));
1414      *
1415      * //array(3) {
1416      * //  [0]=>
1417      * //  string(1) "c"
1418      * //  [1]=>
1419      * //  string(1) "a"
1420      * //  [2]=>
1421      * //  string(1) "b"
1422      * //}
1423      * // The order is random and corresponds to redis' own internal representation of the set structure.
1424      * </pre>
1425      */
1426     public function sMembers( $key ) {}
1427 
1428     /**
1429      * @see sMembers()
1430      * @param   string  $key
1431      * @link    http://redis.io/commands/smembers
1432      */
1433     public function sGetMembers( $key ) {}
1434 
1435     /**
1436      * Sets a value and returns the previous entry at that key.
1437      *
1438      * @param   string  $key
1439      * @param   string  $value
1440      * @return  string  A string, the previous value located at this key.
1441      * @link    http://redis.io/commands/getset
1442      * @example
1443      * <pre>
1444      * $redis->set('x', '42');
1445      * $exValue = $redis->getSet('x', 'lol');   // return '42', replaces x by 'lol'
1446      * $newValue = $redis->get('x')'            // return 'lol'
1447      * </pre>
1448      */
1449     public function getSet( $key, $value ) {}
1450 
1451     /**
1452      * Returns a random key.
1453      *
1454      * @return string: an existing key in redis.
1455      * @link    http://redis.io/commands/randomkey
1456      * @example
1457      * <pre>
1458      * $key = $redis->randomKey();
1459      * $surprise = $redis->get($key);  // who knows what's in there.
1460      * </pre>
1461      */
1462     public function randomKey( ) {}
1463 
1464 
1465     /**
1466      * Switches to a given database.
1467      *
1468      * @param   int     $dbindex
1469      * @return  bool    TRUE in case of success, FALSE in case of failure.
1470      * @link    http://redis.io/commands/select
1471      * @example
1472      * <pre>
1473      * $redis->select(0);       // switch to DB 0
1474      * $redis->set('x', '42');  // write 42 to x
1475      * $redis->move('x', 1);    // move to DB 1
1476      * $redis->select(1);       // switch to DB 1
1477      * $redis->get('x');        // will return 42
1478      * </pre>
1479      */
1480     public function select( $dbindex ) {}
1481 
1482     /**
1483      * Moves a key to a different database.
1484      *
1485      * @param   string  $key
1486      * @param   int     $dbindex
1487      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1488      * @link    http://redis.io/commands/move
1489      * @example
1490      * <pre>
1491      * $redis->select(0);       // switch to DB 0
1492      * $redis->set('x', '42');  // write 42 to x
1493      * $redis->move('x', 1);    // move to DB 1
1494      * $redis->select(1);       // switch to DB 1
1495      * $redis->get('x');        // will return 42
1496      * </pre>
1497      */
1498     public function move( $key, $dbindex ) {}
1499 
1500     /**
1501      * Renames a key.
1502      *
1503      * @param   string  $srcKey
1504      * @param   string  $dstKey
1505      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1506      * @link    http://redis.io/commands/rename
1507      * @example
1508      * <pre>
1509      * $redis->set('x', '42');
1510      * $redis->rename('x', 'y');
1511      * $redis->get('y');   // → 42
1512      * $redis->get('x');   // → `FALSE`
1513      * </pre>
1514      */
1515     public function rename( $srcKey, $dstKey ) {}
1516 
1517     /**
1518      * @see rename()
1519      * @link    http://redis.io/commands/rename
1520      * @param   string  $srcKey
1521      * @param   string  $dstKey
1522      */
1523     public function renameKey( $srcKey, $dstKey ) {}
1524 
1525     /**
1526      * Renames a key.
1527      *
1528      * Same as rename, but will not replace a key if the destination already exists.
1529      * This is the same behaviour as setNx.
1530      *
1531      * @param   string  $srcKey
1532      * @param   string  $dstKey
1533      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1534      * @link    http://redis.io/commands/renamenx
1535      * @example
1536      * <pre>
1537      * $redis->set('x', '42');
1538      * $redis->rename('x', 'y');
1539      * $redis->get('y');   // → 42
1540      * $redis->get('x');   // → `FALSE`
1541      * </pre>
1542      */
1543     public function renameNx( $srcKey, $dstKey ) {}
1544 
1545     /**
1546      * Sets an expiration date (a timeout) on an item.
1547      *
1548      * @param   string  $key    The key that will disappear.
1549      * @param   int     $ttl    The key's remaining Time To Live, in seconds.
1550      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1551      * @link    http://redis.io/commands/expire
1552      * @example
1553      * <pre>
1554      * $redis->set('x', '42');
1555      * $redis->setTimeout('x', 3);  // x will disappear in 3 seconds.
1556      * sleep(5);                    // wait 5 seconds
1557      * $redis->get('x');            // will return `FALSE`, as 'x' has expired.
1558      * </pre>
1559      */
1560     public function expire( $key, $ttl ) {}
1561 
1562     /**
1563      * Sets an expiration date (a timeout in milliseconds) on an item.
1564      *
1565      * @param   string  $key    The key that will disappear.
1566      * @param   int     $pttl   The key's remaining Time To Live, in milliseconds.
1567      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1568      * @link    http://redis.io/commands/pexpire
1569      * @example
1570      * <pre>
1571      * $redis->set('x', '42');
1572      * $redis->pExpire('x', 11500); // x will disappear in 11500 milliseconds.
1573      * $redis->ttl('x');            // 12
1574      * $redis->pttl('x');           // 11500
1575      * </pre>
1576      */
1577     public function pExpire( $key, $ttl ) {}
1578 
1579     /**
1580      * @see expire()
1581      * @param   string  $key
1582      * @param   int     $ttl
1583      * @link    http://redis.io/commands/expire
1584      */
1585     public function setTimeout( $key, $ttl ) {}
1586 
1587     /**
1588      * Sets an expiration date (a timestamp) on an item.
1589      *
1590      * @param   string  $key        The key that will disappear.
1591      * @param   int     $timestamp  Unix timestamp. The key's date of death, in seconds from Epoch time.
1592      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1593      * @link    http://redis.io/commands/expireat
1594      * @example
1595      * <pre>
1596      * $redis->set('x', '42');
1597      * $now = time(NULL);               // current timestamp
1598      * $redis->expireAt('x', $now + 3); // x will disappear in 3 seconds.
1599      * sleep(5);                        // wait 5 seconds
1600      * $redis->get('x');                // will return `FALSE`, as 'x' has expired.
1601      * </pre>
1602      */
1603     public function expireAt( $key, $timestamp ) {}
1604 
1605     /**
1606      * Sets an expiration date (a timestamp) on an item. Requires a timestamp in milliseconds
1607      *
1608      * @param   string  $key        The key that will disappear.
1609      * @param   int     $timestamp  Unix timestamp. The key's date of death, in seconds from Epoch time.
1610      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1611      * @link    http://redis.io/commands/pexpireat
1612      * @example
1613      * <pre>
1614      * $redis->set('x', '42');
1615      * $redis->pExpireAt('x', 1555555555005);
1616      * echo $redis->ttl('x');                       // 218270121
1617      * echo $redis->pttl('x');                      // 218270120575
1618      * </pre>
1619      */
1620     public function pExpireAt( $key, $timestamp ) {}
1621 
1622     /**
1623      * Returns the keys that match a certain pattern.
1624      *
1625      * @param   string  $pattern pattern, using '*' as a wildcard.
1626      * @return  array   of STRING: The keys that match a certain pattern.
1627      * @link    http://redis.io/commands/keys
1628      * @example
1629      * <pre>
1630      * $allKeys = $redis->keys('*');   // all keys will match this.
1631      * $keyWithUserPrefix = $redis->keys('user*');
1632      * </pre>
1633      */
1634     public function keys( $pattern ) {}
1635 
1636     /**
1637      * @see keys()
1638      * @param   string  $pattern
1639      * @link    http://redis.io/commands/keys
1640      */
1641     public function getKeys( $pattern ) {}
1642 
1643     /**
1644      * Returns the current database's size.
1645      *
1646      * @return int:     DB size, in number of keys.
1647      * @link    http://redis.io/commands/dbsize
1648      * @example
1649      * <pre>
1650      * $count = $redis->dbSize();
1651      * echo "Redis has $count keys
";
1652      * </pre>
1653      */
1654     public function dbSize( ) {}
1655 
1656     /**
1657      * Authenticate the connection using a password.
1658      * Warning: The password is sent in plain-text over the network.
1659      *
1660      * @param   string  $password
1661      * @return  bool:   TRUE if the connection is authenticated, FALSE otherwise.
1662      * @link    http://redis.io/commands/auth
1663      * @example $redis->auth('foobared');
1664      */
1665     public function auth( $password ) {}
1666 
1667     /**
1668      * Starts the background rewrite of AOF (Append-Only File)
1669      *
1670      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1671      * @link    http://redis.io/commands/bgrewriteaof
1672      * @example $redis->bgrewriteaof();
1673      */
1674     public function bgrewriteaof( ) {}
1675 
1676     /**
1677      * Changes the slave status
1678      * Either host and port, or no parameter to stop being a slave.
1679      *
1680      * @param   string  $host [optional]
1681      * @param   int $port [optional]
1682      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1683      * @link    http://redis.io/commands/slaveof
1684      * @example
1685      * <pre>
1686      * $redis->slaveof('10.0.1.7', 6379);
1687      * // ...
1688      * $redis->slaveof();
1689      * </pre>
1690      */
1691     public function slaveof( $host = '127.0.0.1', $port = 6379 ) {}
1692 
1693     /**
1694      * Describes the object pointed to by a key.
1695      * The information to retrieve (string) and the key (string).
1696      * Info can be one of the following:
1697      * - "encoding"
1698      * - "refcount"
1699      * - "idletime"
1700      *
1701      * @param   string  $string
1702      * @param   string  $key
1703      * @return  string  for "encoding", int for "refcount" and "idletime", FALSE if the key doesn't exist.
1704      * @link    http://redis.io/commands/object
1705      * @example
1706      * <pre>
1707      * $redis->object("encoding", "l"); // → ziplist
1708      * $redis->object("refcount", "l"); // → 1
1709      * $redis->object("idletime", "l"); // → 400 (in seconds, with a precision of 10 seconds).
1710      * </pre>
1711      */
1712     public function object( $string = '', $key = '' ) {}
1713 
1714     /**
1715      * Performs a synchronous save.
1716      *
1717      * @return  bool:   TRUE in case of success, FALSE in case of failure.
1718      * If a save is already running, this command will fail and return FALSE.
1719      * @link    http://redis.io/commands/save
1720      * @example $redis->save();
1721      */
1722     public function save( ) {}
1723 
1724     /**
1725      * Performs a background save.
1726      *
1727      * @return  bool:    TRUE in case of success, FALSE in case of failure.
1728      * If a save is already running, this command will fail and return FALSE.
1729      * @link    http://redis.io/commands/bgsave
1730      * @example $redis->bgSave();
1731      */
1732     public function bgsave( ) {}
1733 
1734     /**
1735      * Returns the timestamp of the last disk save.
1736      *
1737      * @return  int:    timestamp.
1738      * @link    http://redis.io/commands/lastsave
1739      * @example $redis->lastSave();
1740      */
1741     public function lastSave( ) {}
1742 
1743 
1744     /**
1745      * Returns the type of data pointed by a given key.
1746      *
1747      * @param   string  $key
1748      * @return  int
1749      *
1750      * Depending on the type of the data pointed by the key,
1751      * this method will return the following value:
1752      * - string: Redis::REDIS_STRING
1753      * - set:   Redis::REDIS_SET
1754      * - list:  Redis::REDIS_LIST
1755      * - zset:  Redis::REDIS_ZSET
1756      * - hash:  Redis::REDIS_HASH
1757      * - other: Redis::REDIS_NOT_FOUND
1758      * @link    http://redis.io/commands/type
1759      * @example $redis->type('key');
1760      */
1761     public function type( $key ) {}
1762 
1763     /**
1764      * Append specified string to the string stored in specified key.
1765      *
1766      * @param   string  $key
1767      * @param   string  $value
1768      * @return  int:    Size of the value after the append
1769      * @link    http://redis.io/commands/append
1770      * @example
1771      * <pre>
1772      * $redis->set('key', 'value1');
1773      * $redis->append('key', 'value2'); // 12
1774      * $redis->get('key');              // 'value1value2'
1775      * </pre>
1776      */
1777     public function append( $key, $value ) {}
1778 
1779 
1780     /**
1781      * Return a substring of a larger string
1782      *
1783      * @param   string  $key
1784      * @param   int     $start
1785      * @param   int     $end
1786      * @return  string: the substring
1787      * @link    http://redis.io/commands/getrange
1788      * @example
1789      * <pre>
1790      * $redis->set('key', 'string value');
1791      * $redis->getRange('key', 0, 5);   // 'string'
1792      * $redis->getRange('key', -5, -1); // 'value'
1793      * </pre>
1794      */
1795     public function getRange( $key, $start, $end ) {}
1796 
1797     /**
1798      * Return a substring of a larger string
1799      *
1800      * @deprecated
1801      * @param   string  $key
1802      * @param   int     $start
1803      * @param   int     $end
1804      */
1805     public function substr( $key, $start, $end ) {}
1806 
1807 
1808     /**
1809      * Changes a substring of a larger string.
1810      *
1811      * @param   string  $key
1812      * @param   int     $offset
1813      * @param   string  $value
1814      * @return  string: the length of the string after it was modified.
1815      * @link    http://redis.io/commands/setrange
1816      * @example
1817      * <pre>
1818      * $redis->set('key', 'Hello world');
1819      * $redis->setRange('key', 6, "redis"); // returns 11
1820      * $redis->get('key');                  // "Hello redis"
1821      * </pre>
1822      */
1823     public function setRange( $key, $offset, $value ) {}
1824 
1825     /**
1826      * Get the length of a string value.
1827      *
1828      * @param   string  $key
1829      * @return  int
1830      * @link    http://redis.io/commands/strlen
1831      * @example
1832      * <pre>
1833      * $redis->set('key', 'value');
1834      * $redis->strlen('key'); // 5
1835      * </pre>
1836      */
1837     public function strlen( $key ) {}
1838 
1839     /**
1840      * Return a single bit out of a larger string
1841      *
1842      * @param   string  $key
1843      * @param   int     $offset
1844      * @return  int:    the bit value (0 or 1)
1845      * @link    http://redis.io/commands/getbit
1846      * @example
1847      * <pre>
1848      * $redis->set('key', "x7f");  // this is 0111 1111
1849      * $redis->getBit('key', 0);    // 0
1850      * $redis->getBit('key', 1);    // 1
1851      * </pre>
1852      */
1853     public function getBit( $key, $offset ) {}
1854 
1855     /**
1856      * Changes a single bit of a string.
1857      *
1858      * @param   string  $key
1859      * @param   int     $offset
1860      * @param   bool|int $value bool or int (1 or 0)
1861      * @return  int:    0 or 1, the value of the bit before it was set.
1862      * @link    http://redis.io/commands/setbit
1863      * @example
1864      * <pre>
1865      * $redis->set('key', "*");     // ord("*") = 42 = 0x2f = "0010 1010"
1866      * $redis->setBit('key', 5, 1); // returns 0
1867      * $redis->setBit('key', 7, 1); // returns 0
1868      * $redis->get('key');          // chr(0x2f) = "/" = b("0010 1111")
1869      * </pre>
1870      */
1871     public function setBit( $key, $offset, $value ) {}
1872 
1873     /**
1874      * Count bits in a string.
1875      *
1876      * @param   string  $key
1877      * @return  int     The number of bits set to 1 in the value behind the input key.
1878      * @link    http://redis.io/commands/bitcount
1879      * @example
1880      * <pre>
1881      * $redis->set('bit', '345'); // // 11 0011  0011 0100  0011 0101
1882      * var_dump( $redis->bitCount('bit', 0, 0) ); // int(4)
1883      * var_dump( $redis->bitCount('bit', 1, 1) ); // int(3)
1884      * var_dump( $redis->bitCount('bit', 2, 2) ); // int(4)
1885      * var_dump( $redis->bitCount('bit', 0, 2) ); // int(11)
1886      * </pre>
1887      */
1888     public function bitCount( $key ) {}
1889 
1890     /**
1891      * Bitwise operation on multiple keys.
1892      *
1893      * @param   string  $operation  either "AND", "OR", "NOT", "XOR"
1894      * @param   string  $retKey     return key
1895      * @param   string  $key1
1896      * @param   string  $key2
1897      * @return  int     The size of the string stored in the destination key.
1898      * @link    http://redis.io/commands/bitop
1899      * @example
1900      * <pre>
1901      * $redis->set('bit1', '1'); // 11 0001
1902      * $redis->set('bit2', '2'); // 11 0010
1903      *
1904      * $redis->bitOp('AND', 'bit', 'bit1', 'bit2'); // bit = 110000
1905      * $redis->bitOp('OR',  'bit', 'bit1', 'bit2'); // bit = 110011
1906      * $redis->bitOp('NOT', 'bit', 'bit1', 'bit2'); // bit = 110011
1907      * $redis->bitOp('XOR', 'bit', 'bit1', 'bit2'); // bit = 11
1908      * </pre>
1909      */
1910     public function bitOp( $operation, $retKey, $key1, $key2, $key3 = null ) {}
1911 
1912     /**
1913      * Removes all entries from the current database.
1914      *
1915      * @return  bool: Always TRUE.
1916      * @link    http://redis.io/commands/flushdb
1917      * @example $redis->flushDB();
1918      */
1919     public function flushDB( ) {}
1920 
1921     /**
1922      * Removes all entries from all databases.
1923      *
1924      * @return  bool: Always TRUE.
1925      * @link    http://redis.io/commands/flushall
1926      * @example $redis->flushAll();
1927      */
1928     public function flushAll( ) {}
1929 
1930     /**
1931      * Sort
1932      *
1933      * @param   string  $key
1934      * @param   array   $option array(key => value, ...) - optional, with the following keys and values:
1935      * - 'by' => 'some_pattern_*',
1936      * - 'limit' => array(0, 1),
1937      * - 'get' => 'some_other_pattern_*' or an array of patterns,
1938      * - 'sort' => 'asc' or 'desc',
1939      * - 'alpha' => TRUE,
1940      * - 'store' => 'external-key'
1941      * @return  array
1942      * An array of values, or a number corresponding to the number of elements stored if that was used.
1943      * @link    http://redis.io/commands/sort
1944      * @example
1945      * <pre>
1946      * $redis->delete('s');
1947      * $redis->sadd('s', 5);
1948      * $redis->sadd('s', 4);
1949      * $redis->sadd('s', 2);
1950      * $redis->sadd('s', 1);
1951      * $redis->sadd('s', 3);
1952      *
1953      * var_dump($redis->sort('s')); // 1,2,3,4,5
1954      * var_dump($redis->sort('s', array('sort' => 'desc'))); // 5,4,3,2,1
1955      * var_dump($redis->sort('s', array('sort' => 'desc', 'store' => 'out'))); // (int)5
1956      * </pre>
1957      */
1958     public function sort( $key, $option = null ) {}
1959 
1960 
1961     /**
1962      * Returns an associative array of strings and integers
1963      * @param   string   $option    Optional. The option to provide redis.
1964      * SERVER | CLIENTS | MEMORY | PERSISTENCE | STATS | REPLICATION | CPU | CLASTER | KEYSPACE | COMANDSTATS
1965      *
1966      * Returns an associative array of strings and integers, with the following keys:
1967      * - redis_version
1968      * - redis_git_sha1
1969      * - redis_git_dirty
1970      * - arch_bits
1971      * - multiplexing_api
1972      * - process_id
1973      * - uptime_in_seconds
1974      * - uptime_in_days
1975      * - lru_clock
1976      * - used_cpu_sys
1977      * - used_cpu_user
1978      * - used_cpu_sys_children
1979      * - used_cpu_user_children
1980      * - connected_clients
1981      * - connected_slaves
1982      * - client_longest_output_list
1983      * - client_biggest_input_buf
1984      * - blocked_clients
1985      * - used_memory
1986      * - used_memory_human
1987      * - used_memory_peak
1988      * - used_memory_peak_human
1989      * - mem_fragmentation_ratio
1990      * - mem_allocator
1991      * - loading
1992      * - aof_enabled
1993      * - changes_since_last_save
1994      * - bgsave_in_progress
1995      * - last_save_time
1996      * - total_connections_received
1997      * - total_commands_processed
1998      * - expired_keys
1999      * - evicted_keys
2000      * - keyspace_hits
2001      * - keyspace_misses
2002      * - hash_max_zipmap_entries
2003      * - hash_max_zipmap_value
2004      * - pubsub_channels
2005      * - pubsub_patterns
2006      * - latest_fork_usec
2007      * - vm_enabled
2008      * - role
2009      * @link    http://redis.io/commands/info
2010      * @return string
2011      * @example
2012      * <pre>
2013      * $redis->info();
2014      *
2015      * or
2016      *
2017      * $redis->info("COMMANDSTATS"); //Information on the commands that have been run (>=2.6 only)
2018      * $redis->info("CPU"); // just CPU information from Redis INFO
2019      * </pre>
2020      */
2021     public function info( $option = null ) {}
2022 
2023     /**
2024      * Resets the statistics reported by Redis using the INFO command (`info()` function).
2025      * These are the counters that are reset:
2026      *      - Keyspace hits
2027      *      - Keyspace misses
2028      *      - Number of commands processed
2029      *      - Number of connections received
2030      *      - Number of expired keys
2031      *
2032      * @return bool: `TRUE` in case of success, `FALSE` in case of failure.
2033      * @example $redis->resetStat();
2034      * @link http://redis.io/commands/config-resetstat
2035      */
2036     public function resetStat( ) {}
2037 
2038     /**
2039      * Returns the time to live left for a given key, in seconds. If the key doesn't exist, FALSE is returned.
2040      *
2041      * @param   string  $key
2042      * @return  int,    the time left to live in seconds.
2043      * @link    http://redis.io/commands/ttl
2044      * @example $redis->ttl('key');
2045      */
2046     public function ttl( $key ) {}
2047 
2048     /**
2049      * Returns a time to live left for a given key, in milliseconds.
2050      *
2051      * If the key doesn't exist, FALSE is returned.
2052      *
2053      * @param   string  $key
2054      * @return  int     the time left to live in milliseconds.
2055      * @link    http://redis.io/commands/pttl
2056      * @example $redis->pttl('key');
2057      */
2058     public function pttl( $key ) {}
2059 
2060     /**
2061      * Remove the expiration timer from a key.
2062      *
2063      * @param   string  $key
2064      * @return  bool:   TRUE if a timeout was removed, FALSE if the key didn’t exist or didn’t have an expiration timer.
2065      * @link    http://redis.io/commands/persist
2066      * @example $redis->persist('key');
2067      */
2068     public function persist( $key ) {}
2069 
2070     /**
2071      * Sets multiple key-value pairs in one atomic command.
2072      * MSETNX only returns TRUE if all the keys were set (see SETNX).
2073      *
2074      * @param   array(key => value) $array Pairs: array(key => value, ...)
2075      * @return  bool    TRUE in case of success, FALSE in case of failure.
2076      * @link    http://redis.io/commands/mset
2077      * @example
2078      * <pre>
2079      * $redis->mset(array('key0' => 'value0', 'key1' => 'value1'));
2080      * var_dump($redis->get('key0'));
2081      * var_dump($redis->get('key1'));
2082      * // Output:
2083      * // string(6) "value0"
2084      * // string(6) "value1"
2085      * </pre>
2086      */
2087     public function mset( array $array ) {}
2088 
2089 
2090     /**
2091      * Returns the values of all specified keys.
2092      *
2093      * For every key that does not hold a string value or does not exist,
2094      * the special value false is returned. Because of this, the operation never fails.
2095      *
2096      * @param array $array
2097      * @return array
2098      * @link http://redis.io/commands/mget
2099      * @example
2100      * <pre>
2101      * $redis->delete('x', 'y', 'z', 'h');    // remove x y z
2102      * $redis->mset(array('x' => 'a', 'y' => 'b', 'z' => 'c'));
2103      * $redis->hset('h', 'field', 'value');
2104      * var_dump($redis->mget(array('x', 'y', 'z', 'h')));
2105      * // Output:
2106      * // array(3) {
2107      * // [0]=>
2108      * // string(1) "a"
2109      * // [1]=>
2110      * // string(1) "b"
2111      * // [2]=>
2112      * // string(1) "c"
2113      * // [3]=>
2114      * // bool(false)
2115      * // }
2116      * </pre>
2117      */
2118     public function mget( array $array ) {}
2119 
2120     /**
2121      * @see mset()
2122      * @param   array $array
2123      * @return  int 1 (if the keys were set) or 0 (no key was set)
2124      * @link    http://redis.io/commands/msetnx
2125      */
2126     public function msetnx( array $array ) {}
2127 
2128     /**
2129      * Pops a value from the tail of a list, and pushes it to the front of another list.
2130      * Also return this value.
2131      *
2132      * @since   redis >= 1.1
2133      * @param   string  $srcKey
2134      * @param   string  $dstKey
2135      * @return  string  The element that was moved in case of success, FALSE in case of failure.
2136      * @link    http://redis.io/commands/rpoplpush
2137      * @example
2138      * <pre>
2139      * $redis->delete('x', 'y');
2140      *
2141      * $redis->lPush('x', 'abc');
2142      * $redis->lPush('x', 'def');
2143      * $redis->lPush('y', '123');
2144      * $redis->lPush('y', '456');
2145      *
2146      * // move the last of x to the front of y.
2147      * var_dump($redis->rpoplpush('x', 'y'));
2148      * var_dump($redis->lRange('x', 0, -1));
2149      * var_dump($redis->lRange('y', 0, -1));
2150      *
2151      * //Output:
2152      * //
2153      * //string(3) "abc"
2154      * //array(1) {
2155      * //  [0]=>
2156      * //  string(3) "def"
2157      * //}
2158      * //array(3) {
2159      * //  [0]=>
2160      * //  string(3) "abc"
2161      * //  [1]=>
2162      * //  string(3) "456"
2163      * //  [2]=>
2164      * //  string(3) "123"
2165      * //}
2166      * </pre>
2167      */
2168     public function rpoplpush( $srcKey, $dstKey ) {}
2169 
2170     /**
2171      * A blocking version of rpoplpush, with an integral timeout in the third parameter.
2172      *
2173      * @param   string  $srcKey
2174      * @param   string  $dstKey
2175      * @param   int     $timeout
2176      * @return  string  The element that was moved in case of success, FALSE in case of timeout.
2177      * @link    http://redis.io/commands/brpoplpush
2178      */
2179     public function brpoplpush( $srcKey, $dstKey, $timeout ) {}
2180 
2181     /**
2182      * Adds the specified member with a given score to the sorted set stored at key.
2183      *
2184      * @param   string  $key    Required key
2185      * @param   float   $score1 Required score
2186      * @param   string  $value1 Required value
2187      * @param   float   $score2 Optional score
2188      * @param   string  $value2 Optional value
2189      * @param   float   $scoreN Optional score
2190      * @param   string  $valueN Optional value
2191      * @return  int     Number of values added
2192      * @link    http://redis.io/commands/zadd
2193      * @example
2194      * <pre>
2195      * <pre>
2196      * $redis->zAdd('z', 1, 'v2', 2, 'v2', 3, 'v3', 4, 'v4' );  // int(2)
2197      * $redis->zRem('z', 'v2', 'v3');                           // int(2)
2198      * var_dump( $redis->zRange('z', 0, -1) );
2199      * //// Output:
2200      * // array(2) {
2201      * //   [0]=> string(2) "v1"
2202      * //   [1]=> string(2) "v4"
2203      * // }
2204      * </pre>
2205      * </pre>
2206      */
2207     public function zAdd( $key, $score1, $value1, $score2 = null, $value2 = null, $scoreN = null, $valueN = null ) {}
2208 
2209     /**
2210      * Returns a range of elements from the ordered set stored at the specified key,
2211      * with values in the range [start, end]. start and stop are interpreted as zero-based indices:
2212      * 0 the first element,
2213      * 1 the second ...
2214      * -1 the last element,
2215      * -2 the penultimate ...
2216      *
2217      * @param   string  $key
2218      * @param   int     $start
2219      * @param   int     $end
2220      * @param   bool    $withscores
2221      * @return  array   Array containing the values in specified range.
2222      * @link    http://redis.io/commands/zrange
2223      * @example
2224      * <pre>
2225      * $redis->zAdd('key1', 0, 'val0');
2226      * $redis->zAdd('key1', 2, 'val2');
2227      * $redis->zAdd('key1', 10, 'val10');
2228      * $redis->zRange('key1', 0, -1); // array('val0', 'val2', 'val10')
2229      * // with scores
2230      * $redis->zRange('key1', 0, -1, true); // array('val0' => 0, 'val2' => 2, 'val10' => 10)
2231      * </pre>
2232      */
2233     public function zRange( $key, $start, $end, $withscores = null ) {}
2234 
2235     /**
2236      * Deletes a specified member from the ordered set.
2237      *
2238      * @param   string  $key
2239      * @param   string  $member1
2240      * @param   string  $member2
2241      * @param   string  $memberN
2242      * @return  int     Number of deleted values
2243      * @link    http://redis.io/commands/zrem
2244      * @example
2245      * <pre>
2246      * $redis->zAdd('z', 1, 'v2', 2, 'v2', 3, 'v3', 4, 'v4' );  // int(2)
2247      * $redis->zRem('z', 'v2', 'v3');                           // int(2)
2248      * var_dump( $redis->zRange('z', 0, -1) );
2249      * //// Output:
2250      * // array(2) {
2251      * //   [0]=> string(2) "v1"
2252      * //   [1]=> string(2) "v4"
2253      * // }
2254      * </pre>
2255      */
2256     public function zRem( $key, $member1, $member2 = null, $memberN = null ) {}
2257 
2258     /**
2259      * @see zRem()
2260      * @param   string  $key
2261      * @param   string  $member1
2262      * @param   string  $member2
2263      * @param   string  $memberN
2264      * @return  int     Number of deleted values
2265      * @link    http://redis.io/commands/zrem
2266      */
2267     public function zDelete( $key, $member1, $member2 = null, $memberN = null ) {}
2268 
2269     /**
2270      * Returns the elements of the sorted set stored at the specified key in the range [start, end]
2271      * in reverse order. start and stop are interpretated as zero-based indices:
2272      * 0 the first element,
2273      * 1 the second ...
2274      * -1 the last element,
2275      * -2 the penultimate ...
2276      *
2277      * @param   string  $key
2278      * @param   int     $start
2279      * @param   int     $end
2280      * @param   bool    $withscore
2281      * @return  array   Array containing the values in specified range.
2282      * @link    http://redis.io/commands/zrevrange
2283      * @example
2284      * <pre>
2285      * $redis->zAdd('key', 0, 'val0');
2286      * $redis->zAdd('key', 2, 'val2');
2287      * $redis->zAdd('key', 10, 'val10');
2288      * $redis->zRevRange('key', 0, -1); // array('val10', 'val2', 'val0')
2289      *
2290      * // with scores
2291      * $redis->zRevRange('key', 0, -1, true); // array('val10' => 10, 'val2' => 2, 'val0' => 0)
2292      * </pre>
2293      */
2294     public function zRevRange( $key, $start, $end, $withscore = null ) {}
2295 
2296     /**
2297      * Returns the elements of the sorted set stored at the specified key which have scores in the
2298      * range [start,end]. Adding a parenthesis before start or end excludes it from the range.
2299      * +inf and -inf are also valid limits.
2300      *
2301      * zRevRangeByScore returns the same items in reverse order, when the start and end parameters are swapped.
2302      *
2303      * @param   string  $key
2304      * @param   int     $start
2305      * @param   int     $end
2306      * @param   array   $options Two options are available:
2307      *                      - withscores => TRUE,
2308      *                      - and limit => array($offset, $count)
2309      * @return  array   Array containing the values in specified range.
2310      * @link    http://redis.io/commands/zrangebyscore
2311      * @example
2312      * <pre>
2313      * $redis->zAdd('key', 0, 'val0');
2314      * $redis->zAdd('key', 2, 'val2');
2315      * $redis->zAdd('key', 10, 'val10');
2316      * $redis->zRangeByScore('key', 0, 3);                                          // array('val0', 'val2')
2317      * $redis->zRangeByScore('key', 0, 3, array('withscores' => TRUE);              // array('val0' => 0, 'val2' => 2)
2318      * $redis->zRangeByScore('key', 0, 3, array('limit' => array(1, 1));                        // array('val2' => 2)
2319      * $redis->zRangeByScore('key', 0, 3, array('limit' => array(1, 1));                        // array('val2')
2320      * $redis->zRangeByScore('key', 0, 3, array('withscores' => TRUE, 'limit' => array(1, 1));  // array('val2' => 2)
2321      * </pre>
2322      */
2323     public function zRangeByScore( $key, $start, $end, array $options = array() ) {}
2324 
2325     /**
2326      * @see zRangeByScore()
2327      * @param   string  $key
2328      * @param   int     $start
2329      * @param   int     $end
2330      * @param   array   $options
2331      *
2332      * @return     array
2333      */
2334     public function zRevRangeByScore( $key, $start, $end, array $options = array() ) {}
2335 
2336     /**
2337      * Returns the number of elements of the sorted set stored at the specified key which have
2338      * scores in the range [start,end]. Adding a parenthesis before start or end excludes it
2339      * from the range. +inf and -inf are also valid limits.
2340      *
2341      * @param   string  $key
2342      * @param   string  $start
2343      * @param   string  $end
2344      * @return  int     the size of a corresponding zRangeByScore.
2345      * @link    http://redis.io/commands/zcount
2346      * @example
2347      * <pre>
2348      * $redis->zAdd('key', 0, 'val0');
2349      * $redis->zAdd('key', 2, 'val2');
2350      * $redis->zAdd('key', 10, 'val10');
2351      * $redis->zCount('key', 0, 3); // 2, corresponding to array('val0', 'val2')
2352      * </pre>
2353      */
2354     public function zCount( $key, $start, $end ) {}
2355 
2356     /**
2357      * Deletes the elements of the sorted set stored at the specified key which have scores in the range [start,end].
2358      *
2359      * @param   string          $key
2360      * @param   float|string    $start double or "+inf" or "-inf" string
2361      * @param   float|string    $end double or "+inf" or "-inf" string
2362      * @return  int             The number of values deleted from the sorted set
2363      * @link    http://redis.io/commands/zremrangebyscore
2364      * @example
2365      * <pre>
2366      * $redis->zAdd('key', 0, 'val0');
2367      * $redis->zAdd('key', 2, 'val2');
2368      * $redis->zAdd('key', 10, 'val10');
2369      * $redis->zRemRangeByScore('key', 0, 3); // 2
2370      * </pre>
2371      */
2372     public function zRemRangeByScore( $key, $start, $end ) {}
2373 
2374     /**
2375      * @see zRemRangeByScore()
2376      * @param string    $key
2377      * @param float     $start
2378      * @param float     $end
2379      */
2380     public function zDeleteRangeByScore( $key, $start, $end ) {}
2381 
2382     /**
2383      * Deletes the elements of the sorted set stored at the specified key which have rank in the range [start,end].
2384      *
2385      * @param   string  $key
2386      * @param   int     $start
2387      * @param   int     $end
2388      * @return  int     The number of values deleted from the sorted set
2389      * @link    http://redis.io/commands/zremrangebyrank
2390      * @example
2391      * <pre>
2392      * $redis->zAdd('key', 1, 'one');
2393      * $redis->zAdd('key', 2, 'two');
2394      * $redis->zAdd('key', 3, 'three');
2395      * $redis->zRemRangeByRank('key', 0, 1); // 2
2396      * $redis->zRange('key', 0, -1, array('withscores' => TRUE)); // array('three' => 3)
2397      * </pre>
2398      */
2399     public function zRemRangeByRank( $key, $start, $end ) {}
2400 
2401     /**
2402      * @see zRemRangeByRank()
2403      * @param   string  $key
2404      * @param   int     $start
2405      * @param   int     $end
2406      * @link    http://redis.io/commands/zremrangebyscore
2407      */
2408     public function zDeleteRangeByRank( $key, $start, $end ) {}
2409 
2410     /**
2411      * Returns the cardinality of an ordered set.
2412      *
2413      * @param   string  $key
2414      * @return  int     the set's cardinality
2415      * @link    http://redis.io/commands/zsize
2416      * @example
2417      * <pre>
2418      * $redis->zAdd('key', 0, 'val0');
2419      * $redis->zAdd('key', 2, 'val2');
2420      * $redis->zAdd('key', 10, 'val10');
2421      * $redis->zCard('key');            // 3
2422      * </pre>
2423      */
2424     public function zCard( $key ) {}
2425 
2426     /**
2427      * @see zCard()
2428      * @param string $key
2429      */
2430     public function zSize( $key ) {}
2431 
2432     /**
2433      * Returns the score of a given member in the specified sorted set.
2434      *
2435      * @param   string  $key
2436      * @param   string  $member
2437      * @return  float
2438      * @link    http://redis.io/commands/zscore
2439      * @example
2440      * <pre>
2441      * $redis->zAdd('key', 2.5, 'val2');
2442      * $redis->zScore('key', 'val2'); // 2.5
2443      * </pre>
2444      */
2445     public function zScore( $key, $member ) {}
2446 
2447     /**
2448      * Returns the rank of a given member in the specified sorted set, starting at 0 for the item
2449      * with the smallest score. zRevRank starts at 0 for the item with the largest score.
2450      *
2451      * @param   string  $key
2452      * @param   string  $member
2453      * @return  int     the item's score.
2454      * @link    http://redis.io/commands/zrank
2455      * @example
2456      * <pre>
2457      * $redis->delete('z');
2458      * $redis->zAdd('key', 1, 'one');
2459      * $redis->zAdd('key', 2, 'two');
2460      * $redis->zRank('key', 'one');     // 0
2461      * $redis->zRank('key', 'two');     // 1
2462      * $redis->zRevRank('key', 'one');  // 1
2463      * $redis->zRevRank('key', 'two');  // 0
2464      * </pre>
2465      */
2466     public function zRank( $key, $member ) {}
2467 
2468     /**
2469      * @see zRank()
2470      * @param  string $key
2471      * @param  string $member
2472      * @return int    the item's score
2473      * @link   http://redis.io/commands/zrevrank
2474      */
2475     public function zRevRank( $key, $member ) {}
2476 
2477     /**
2478      * Increments the score of a member from a sorted set by a given amount.
2479      *
2480      * @param   string  $key
2481      * @param   float   $value (double) value that will be added to the member's score
2482      * @param   string  $member
2483      * @return  float   the new value
2484      * @link    http://redis.io/commands/zincrby
2485      * @example
2486      * <pre>
2487      * $redis->delete('key');
2488      * $redis->zIncrBy('key', 2.5, 'member1');  // key or member1 didn't exist, so member1's score is to 0
2489      *                                          // before the increment and now has the value 2.5
2490      * $redis->zIncrBy('key', 1, 'member1');    // 3.5
2491      * </pre>
2492      */
2493     public function zIncrBy( $key, $value, $member ) {}
2494 
2495     /**
2496      * Creates an union of sorted sets given in second argument.
2497      * The result of the union will be stored in the sorted set defined by the first argument.
2498      * The third optionnel argument defines weights to apply to the sorted sets in input.
2499      * In this case, the weights will be multiplied by the score of each element in the sorted set
2500      * before applying the aggregation. The forth argument defines the AGGREGATE option which
2501      * specify how the results of the union are aggregated.
2502      *
2503      * @param string    $Output
2504      * @param array     $ZSetKeys
2505      * @param array     $Weights
2506      * @param string    $aggregateFunction  Either "SUM", "MIN", or "MAX": defines the behaviour to use on
2507      * duplicate entries during the zUnion.
2508      * @return int The number of values in the new sorted set.
2509      * @link    http://redis.io/commands/zunionstore
2510      * @example
2511      * <pre>
2512      * $redis->delete('k1');
2513      * $redis->delete('k2');
2514      * $redis->delete('k3');
2515      * $redis->delete('ko1');
2516      * $redis->delete('ko2');
2517      * $redis->delete('ko3');
2518      *
2519      * $redis->zAdd('k1', 0, 'val0');
2520      * $redis->zAdd('k1', 1, 'val1');
2521      *
2522      * $redis->zAdd('k2', 2, 'val2');
2523      * $redis->zAdd('k2', 3, 'val3');
2524      *
2525      * $redis->zUnion('ko1', array('k1', 'k2')); // 4, 'ko1' => array('val0', 'val1', 'val2', 'val3')
2526      *
2527      * // Weighted zUnion
2528      * $redis->zUnion('ko2', array('k1', 'k2'), array(1, 1)); // 4, 'ko2' => array('val0', 'val1', 'val2', 'val3')
2529      * $redis->zUnion('ko3', array('k1', 'k2'), array(5, 1)); // 4, 'ko3' => array('val0', 'val2', 'val3', 'val1')
2530      * </pre>
2531      */
2532     public function zUnion($Output, $ZSetKeys, array $Weights = null, $aggregateFunction = 'SUM') {}
2533 
2534     /**
2535      * Creates an intersection of sorted sets given in second argument.
2536      * The result of the union will be stored in the sorted set defined by the first argument.
2537      * The third optional argument defines weights to apply to the sorted sets in input.
2538      * In this case, the weights will be multiplied by the score of each element in the sorted set
2539      * before applying the aggregation. The forth argument defines the AGGREGATE option which
2540      * specify how the results of the union are aggregated.
2541      *
2542      * @param   string  $Output
2543      * @param   array   $ZSetKeys
2544      * @param   array   $Weights
2545      * @param   string  $aggregateFunction Either "SUM", "MIN", or "MAX":
2546      * defines the behaviour to use on duplicate entries during the zInter.
2547      * @return  int     The number of values in the new sorted set.
2548      * @link    http://redis.io/commands/zinterstore
2549      * @example
2550      * <pre>
2551      * $redis->delete('k1');
2552      * $redis->delete('k2');
2553      * $redis->delete('k3');
2554      *
2555      * $redis->delete('ko1');
2556      * $redis->delete('ko2');
2557      * $redis->delete('ko3');
2558      * $redis->delete('ko4');
2559      *
2560      * $redis->zAdd('k1', 0, 'val0');
2561      * $redis->zAdd('k1', 1, 'val1');
2562      * $redis->zAdd('k1', 3, 'val3');
2563      *
2564      * $redis->zAdd('k2', 2, 'val1');
2565      * $redis->zAdd('k2', 3, 'val3');
2566      *
2567      * $redis->zInter('ko1', array('k1', 'k2'));               // 2, 'ko1' => array('val1', 'val3')
2568      * $redis->zInter('ko2', array('k1', 'k2'), array(1, 1));  // 2, 'ko2' => array('val1', 'val3')
2569      *
2570      * // Weighted zInter
2571      * $redis->zInter('ko3', array('k1', 'k2'), array(1, 5), 'min'); // 2, 'ko3' => array('val1', 'val3')
2572      * $redis->zInter('ko4', array('k1', 'k2'), array(1, 5), 'max'); // 2, 'ko4' => array('val3', 'val1')
2573      * </pre>
2574      */
2575     public function zInter($Output, $ZSetKeys, array $Weights = null, $aggregateFunction = 'SUM') {}
2576 
2577     /**
2578      * Adds a value to the hash stored at key. If this value is already in the hash, FALSE is returned.
2579      *
2580      * @param string $key
2581      * @param string $hashKey
2582      * @param string $value
2583      * @return int
2584      * 1 if value didn't exist and was added successfully,
2585      * 0 if the value was already present and was replaced, FALSE if there was an error.
2586      * @link    http://redis.io/commands/hset
2587      * @example
2588      * <pre>
2589      * $redis->delete('h')
2590      * $redis->hSet('h', 'key1', 'hello');  // 1, 'key1' => 'hello' in the hash at "h"
2591      * $redis->hGet('h', 'key1');           // returns "hello"
2592      *
2593      * $redis->hSet('h', 'key1', 'plop');   // 0, value was replaced.
2594      * $redis->hGet('h', 'key1');           // returns "plop"
2595      * </pre>
2596      */
2597     public function hSet( $key, $hashKey, $value ) {}
2598 
2599     /**
2600      * Adds a value to the hash stored at key only if this field isn't already in the hash.
2601      *
2602      * @param   string  $key
2603      * @param   string  $hashKey
2604      * @param   string  $value
2605      * @return  bool    TRUE if the field was set, FALSE if it was already present.
2606      * @link    http://redis.io/commands/hsetnx
2607      * @example
2608      * <pre>
2609      * $redis->delete('h')
2610      * $redis->hSetNx('h', 'key1', 'hello'); // TRUE, 'key1' => 'hello' in the hash at "h"
2611      * $redis->hSetNx('h', 'key1', 'world'); // FALSE, 'key1' => 'hello' in the hash at "h". No change since the field
2612      * wasn't replaced.
2613      * </pre>
2614      */
2615     public function hSetNx( $key, $hashKey, $value ) {}
2616 
2617     /**
2618      * Gets a value from the hash stored at key.
2619      * If the hash table doesn't exist, or the key doesn't exist, FALSE is returned.
2620      *
2621      * @param   string  $key
2622      * @param   string  $hashKey
2623      * @return  string  The value, if the command executed successfully BOOL FALSE in case of failure
2624      * @link    http://redis.io/commands/hget
2625      */
2626     public function hGet($key, $hashKey) {}
2627 
2628     /**
2629      * Returns the length of a hash, in number of items
2630      *
2631      * @param   string  $key
2632      * @return  int     the number of items in a hash, FALSE if the key doesn't exist or isn't a hash.
2633      * @link    http://redis.io/commands/hlen
2634      * @example
2635      * <pre>
2636      * $redis->delete('h')
2637      * $redis->hSet('h', 'key1', 'hello');
2638      * $redis->hSet('h', 'key2', 'plop');
2639      * $redis->hLen('h'); // returns 2
2640      * </pre>
2641      */
2642     public function hLen( $key ) {}
2643 
2644     /**
2645      * Removes a values from the hash stored at key.
2646      * If the hash table doesn't exist, or the key doesn't exist, FALSE is returned.
2647      *
2648      * @param   string  $key
2649      * @param   string  $hashKey1
2650      * @param   string  $hashKey2
2651      * @param   string  $hashKeyN
2652      * @return  int     Number of deleted fields
2653      * @link    http://redis.io/commands/hdel
2654      * @example
2655      * <pre>
2656      * $redis->hMSet('h',
2657      *               array(
2658      *                    'f1' => 'v1',
2659      *                    'f2' => 'v2',
2660      *                    'f3' => 'v3',
2661      *                    'f4' => 'v4',
2662      *               ));
2663      *
2664      * var_dump( $redis->hDel('h', 'f1') );        // int(1)
2665      * var_dump( $redis->hDel('h', 'f2', 'f3') );  // int(2)
2666      * s
2667      * var_dump( $redis->hGetAll('h') );
2668      * //// Output:
2669      * //  array(1) {
2670      * //    ["f4"]=> string(2) "v4"
2671      * //  }
2672      * </pre>
2673      */
2674     public function hDel( $key, $hashKey1, $hashKey2 = null, $hashKeyN = null ) {}
2675 
2676     /**
2677      * Returns the keys in a hash, as an array of strings.
2678      *
2679      * @param   string  $key
2680      * @return  array   An array of elements, the keys of the hash. This works like PHP's array_keys().
2681      * @link    http://redis.io/commands/hkeys
2682      * @example
2683      * <pre>
2684      * $redis->delete('h');
2685      * $redis->hSet('h', 'a', 'x');
2686      * $redis->hSet('h', 'b', 'y');
2687      * $redis->hSet('h', 'c', 'z');
2688      * $redis->hSet('h', 'd', 't');
2689      * var_dump($redis->hKeys('h'));
2690      *
2691      * // Output:
2692      * // array(4) {
2693      * // [0]=>
2694      * // string(1) "a"
2695      * // [1]=>
2696      * // string(1) "b"
2697      * // [2]=>
2698      * // string(1) "c"
2699      * // [3]=>
2700      * // string(1) "d"
2701      * // }
2702      * // The order is random and corresponds to redis' own internal representation of the set structure.
2703      * </pre>
2704      */
2705     public function hKeys( $key ) {}
2706 
2707     /**
2708      * Returns the values in a hash, as an array of strings.
2709      *
2710      * @param   string  $key
2711      * @return  array   An array of elements, the values of the hash. This works like PHP's array_values().
2712      * @link    http://redis.io/commands/hvals
2713      * @example
2714      * <pre>
2715      * $redis->delete('h');
2716      * $redis->hSet('h', 'a', 'x');
2717      * $redis->hSet('h', 'b', 'y');
2718      * $redis->hSet('h', 'c', 'z');
2719      * $redis->hSet('h', 'd', 't');
2720      * var_dump($redis->hVals('h'));
2721      *
2722      * // Output
2723      * // array(4) {
2724      * //   [0]=>
2725      * //   string(1) "x"
2726      * //   [1]=>
2727      * //   string(1) "y"
2728      * //   [2]=>
2729      * //   string(1) "z"
2730      * //   [3]=>
2731      * //   string(1) "t"
2732      * // }
2733      * // The order is random and corresponds to redis' own internal representation of the set structure.
2734      * </pre>
2735      */
2736     public function hVals( $key ) {}
2737 
2738     /**
2739      * Returns the whole hash, as an array of strings indexed by strings.
2740      *
2741      * @param   string  $key
2742      * @return  array   An array of elements, the contents of the hash.
2743      * @link    http://redis.io/commands/hgetall
2744      * @example
2745      * <pre>
2746      * $redis->delete('h');
2747      * $redis->hSet('h', 'a', 'x');
2748      * $redis->hSet('h', 'b', 'y');
2749      * $redis->hSet('h', 'c', 'z');
2750      * $redis->hSet('h', 'd', 't');
2751      * var_dump($redis->hGetAll('h'));
2752      *
2753      * // Output:
2754      * // array(4) {
2755      * //   ["a"]=>
2756      * //   string(1) "x"
2757      * //   ["b"]=>
2758      * //   string(1) "y"
2759      * //   ["c"]=>
2760      * //   string(1) "z"
2761      * //   ["d"]=>
2762      * //   string(1) "t"
2763      * // }
2764      * // The order is random and corresponds to redis' own internal representation of the set structure.
2765      * </pre>
2766      */
2767     public function hGetAll( $key ) {}
2768 
2769     /**
2770      * Verify if the specified member exists in a key.
2771      *
2772      * @param   string  $key
2773      * @param   string  $hashKey
2774      * @return  bool:   If the member exists in the hash table, return TRUE, otherwise return FALSE.
2775      * @link    http://redis.io/commands/hexists
2776      * @example
2777      * <pre>
2778      * $redis->hSet('h', 'a', 'x');
2779      * $redis->hExists('h', 'a');               //  TRUE
2780      * $redis->hExists('h', 'NonExistingKey');  // FALSE
2781      * </pre>
2782      */
2783     public function hExists( $key, $hashKey ) {}
2784 
2785     /**
2786      * Increments the value of a member from a hash by a given amount.
2787      *
2788      * @param   string  $key
2789      * @param   string  $hashKey
2790      * @param   int     $value (integer) value that will be added to the member's value
2791      * @return  int     the new value
2792      * @link    http://redis.io/commands/hincrby
2793      * @example
2794      * <pre>
2795      * $redis->delete('h');
2796      * $redis->hIncrBy('h', 'x', 2); // returns 2: h[x] = 2 now.
2797      * $redis->hIncrBy('h', 'x', 1); // h[x] ← 2 + 1. Returns 3
2798      * </pre>
2799      */
2800     public function hIncrBy( $key, $hashKey, $value ) {}
2801 
2802     /**
2803      * Increment the float value of a hash field by the given amount
2804      * @param   string  $key
2805      * @param   string  $field
2806      * @param   float   $increment
2807      * @return  float
2808      * @link    http://redis.io/commands/hincrbyfloat
2809      * @example
2810      * <pre>
2811      * $redis = new Redis();
2812      * $redis->connect('127.0.0.1');
2813      * $redis->hset('h', 'float', 3);
2814      * $redis->hset('h', 'int',   3);
2815      * var_dump( $redis->hIncrByFloat('h', 'float', 1.5) ); // float(4.5)
2816      *
2817      * var_dump( $redis->hGetAll('h') );
2818      *
2819      * // Output
2820      *  array(2) {
2821      *    ["float"]=>
2822      *    string(3) "4.5"
2823      *    ["int"]=>
2824      *    string(1) "3"
2825      *  }
2826      * </pre>
2827      */
2828     public function hIncrByFloat( $key, $field, $increment ) {}
2829 
2830     /**
2831      * Fills in a whole hash. Non-string values are converted to string, using the standard (string) cast.
2832      * NULL values are stored as empty strings
2833      *
2834      * @param   string  $key
2835      * @param   array   $hashKeys key → value array
2836      * @return  bool
2837      * @link    http://redis.io/commands/hmset
2838      * @example
2839      * <pre>
2840      * $redis->delete('user:1');
2841      * $redis->hMset('user:1', array('name' => 'Joe', 'salary' => 2000));
2842      * $redis->hIncrBy('user:1', 'salary', 100); // Joe earns 100 more now.
2843      * </pre>
2844      */
2845     public function hMset( $key, $hashKeys ) {}
2846 
2847     /**
2848      * Retirieve the values associated to the specified fields in the hash.
2849      *
2850      * @param   string  $key
2851      * @param   array   $hashKeys
2852      * @return  array   Array An array of elements, the values of the specified fields in the hash,
2853      * with the hash keys as array keys.
2854      * @link    http://redis.io/commands/hmget
2855      * @example
2856      * <pre>
2857      * $redis->delete('h');
2858      * $redis->hSet('h', 'field1', 'value1');
2859      * $redis->hSet('h', 'field2', 'value2');
2860      * $redis->hmGet('h', array('field1', 'field2')); // returns array('field1' => 'value1', 'field2' => 'value2')
2861      * </pre>
2862      */
2863     public function hMGet( $key, $hashKeys ) {}
2864 
2865     /**
2866      * Get or Set the redis config keys.
2867      *
2868      * @param   string  $operation  either `GET` or `SET`
2869      * @param   string  $key        for `SET`, glob-pattern for `GET`. See http://redis.io/commands/config-get for examples.
2870      * @param   string  $value      optional string (only for `SET`)
2871      * @return  array   Associative array for `GET`, key -> value
2872      * @link    http://redis.io/commands/config-get
2873      * @link    http://redis.io/commands/config-set
2874      * @example
2875      * <pre>
2876      * $redis->config("GET", "*max-*-entries*");
2877      * $redis->config("SET", "dir", "/var/run/redis/dumps/");
2878      * </pre>
2879      */
2880     public function config( $operation, $key, $value ) {}
2881 
2882     /**
2883      * @see eval()
2884      * @param string $script
2885      * @param array  $args
2886      * @param int    $numKeys
2887      */
2888     public function evaluate( $script, $args = array(), $numKeys = 0 ) {}
2889 
2890     /**
2891      * Evaluate a LUA script serverside, from the SHA1 hash of the script instead of the script itself.
2892      * In order to run this command Redis will have to have already loaded the script, either by running it or via
2893      * the SCRIPT LOAD command.
2894      * @param   string  $scriptSha
2895      * @param   array   $args
2896      * @param   int     $numKeys
2897      * @return  mixed. @see eval()
2898      * @see     eval()
2899      * @link    http://redis.io/commands/evalsha
2900      * @example
2901      * <pre>
2902      * $script = 'return 1';
2903      * $sha = $redis->script('load', $script);
2904      * $redis->evalSha($sha); // Returns 1
2905      * </pre>
2906      */
2907     public function evalSha( $scriptSha, $args = array(), $numKeys = 0 ) {}
2908 
2909     /**
2910      * @see evalSha()
2911      * @param string $scriptSha
2912      * @param array  $args
2913      * @param int    $numKeys
2914      */
2915     public function evaluateSha( $scriptSha, $args = array(), $numKeys = 0 ) {}
2916 
2917     /**
2918      * Execute the Redis SCRIPT command to perform various operations on the scripting subsystem.
2919      * @param   string  $command load | flush | kill | exists
2920      * @param   string  $script
2921      * @return  mixed
2922      * @link    http://redis.io/commands/script-load
2923      * @link    http://redis.io/commands/script-kill
2924      * @link    http://redis.io/commands/script-flush
2925      * @link    http://redis.io/commands/script-exists
2926      * @example
2927      * <pre>
2928      * $redis->script('load', $script);
2929      * $redis->script('flush');
2930      * $redis->script('kill');
2931      * $redis->script('exists', $script1, [$script2, $script3, ...]);
2932      * </pre>
2933      *
2934      * SCRIPT LOAD will return the SHA1 hash of the passed script on success, and FALSE on failure.
2935      * SCRIPT FLUSH should always return TRUE
2936      * SCRIPT KILL will return true if a script was able to be killed and false if not
2937      * SCRIPT EXISTS will return an array with TRUE or FALSE for each passed script
2938      */
2939     public function script( $command, $script ) {}
2940 
2941     /**
2942      * The last error message (if any)
2943      * @return  string  A string with the last returned script based error message, or NULL if there is no error
2944      * @example
2945      * <pre>
2946      * $redis->eval('this-is-not-lua');
2947      * $err = $redis->getLastError();
2948      * // "ERR Error compiling script (new function): user_script:1: '=' expected near '-'"
2949      * </pre>
2950      */
2951     public function getLastError() {}
2952 
2953     /**
2954      * Clear the last error message
2955      *
2956      * @return bool true
2957      * @example
2958      * <pre>
2959      * $redis->set('x', 'a');
2960      * $redis->incr('x');
2961      * $err = $redis->getLastError();
2962      * // "ERR value is not an integer or out of range"
2963      * $redis->clearLastError();
2964      * $err = $redis->getLastError();
2965      * // NULL
2966      * </pre>
2967      */
2968     public function clearLastError() {}
2969 
2970     /**
2971      * A utility method to prefix the value with the prefix setting for phpredis.
2972      * @param   $value  The value you wish to prefix
2973      * @return  string  If a prefix is set up, the value now prefixed.  If there is no prefix, the value will be returned unchanged.
2974      * @example
2975      * <pre>
2976      * $redis->setOption(Redis::OPT_PREFIX, 'my-prefix:');
2977      * $redis->_prefix('my-value'); // Will return 'my-prefix:my-value'
2978      * </pre>
2979      */
2980     public function _prefix( $value ) {}
2981 
2982     /**
2983      * A utility method to unserialize data with whatever serializer is set up.  If there is no serializer set, the
2984      * value will be returned unchanged.  If there is a serializer set up, and the data passed in is malformed, an
2985      * exception will be thrown. This can be useful if phpredis is serializing values, and you return something from
2986      * redis in a LUA script that is serialized.
2987      * @param   string  $value  The value to be unserialized
2988      * @return mixed
2989      * @example
2990      * <pre>
2991      * $redis->setOption(Redis::OPT_SERIALIZER, Redis::SERIALIZER_PHP);
2992      * $redis->_unserialize('a:3:{i:0;i:1;i:1;i:2;i:2;i:3;}'); // Will return Array(1,2,3)
2993      * </pre>
2994      */
2995     public function _unserialize( $value ) {}
2996 
2997     /**
2998      * Dump a key out of a redis database, the value of which can later be passed into redis using the RESTORE command.
2999      * The data that comes out of DUMP is a binary representation of the key as Redis stores it.
3000      * @param   string  $key
3001      * @return  string  The Redis encoded value of the key, or FALSE if the key doesn't exist
3002      * @link    http://redis.io/commands/dump
3003      * @example
3004      * <pre>
3005      * $redis->set('foo', 'bar');
3006      * $val = $redis->dump('foo'); // $val will be the Redis encoded key value
3007      * </pre>
3008      */
3009     public function dump( $key ) {}
3010 
3011     /**
3012      * Restore a key from the result of a DUMP operation.
3013      *
3014      * @param   string  $key    The key name
3015      * @param   int     $ttl    How long the key should live (if zero, no expire will be set on the key)
3016      * @param   string  $value  (binary).  The Redis encoded key value (from DUMP)
3017      * @return  bool
3018      * @link    http://redis.io/commands/restore
3019      * @example
3020      * <pre>
3021      * $redis->set('foo', 'bar');
3022      * $val = $redis->dump('foo');
3023      * $redis->restore('bar', 0, $val); // The key 'bar', will now be equal to the key 'foo'
3024      * </pre>
3025      */
3026     public function restore( $key, $ttl, $value ) {}
3027 
3028     /**
3029      * Migrates a key to a different Redis instance.
3030      *
3031      * @param   string  $host       The destination host
3032      * @param   int     $port       The TCP port to connect to.
3033      * @param   string  $key        The key to migrate.
3034      * @param   int     $db         The target DB.
3035      * @param   int     $timeout    The maximum amount of time given to this transfer.
3036      * @return  bool
3037      * @link    http://redis.io/commands/migrate
3038      * @example
3039      * <pre>
3040      * $redis->migrate('backup', 6379, 'foo', 0, 3600);
3041      * </pre>
3042      */
3043     public function migrate( $host, $port, $key, $db, $timeout ) {}
3044 
3045     /**
3046      * Return the current Redis server time.
3047      * @return  array If successfull, the time will come back as an associative array with element zero being the
3048      * unix timestamp, and element one being microseconds.
3049      * @link    http://redis.io/commands/time
3050      * <pre>
3051      * var_dump( $redis->time() );
3052      * // array(2) {
3053      * //   [0] => string(10) "1342364352"
3054      * //   [1] => string(6) "253002"
3055      * // }
3056      * </pre>
3057      */
3058     public function time() {}
3059 }
3060 
3061 class RedisException extends Exception {}
3062 
3063 class RedisArray {
3064     /**
3065      * Constructor
3066      *
3067      * @param   string  $name   Name of the redis array to create (required if using redis.ini to define array)
3068      * @param   array   $hosts  Array of hosts to construct the array with
3069      * @param   array   $opts   Array of options
3070      * @link    https://github.com/nicolasff/phpredis/blob/master/arrays.markdown
3071      */
3072     function __construct($name = '', array $hosts = NULL, array $opts = NULL) {}
3073 
3074     /**
3075      * @return  array   list of hosts for the selected array
3076      */
3077     public function _hosts() {}
3078 
3079     /**
3080      * @return  string  the name of the function used to extract key parts during consistent hashing
3081      */
3082     public function _function() {}
3083 
3084     /**
3085      * @param   string  key     The key for which you want to lookup the host
3086      * @return  string  the host to be used for a certain key
3087      */
3088     public function _target($key) {}
3089 
3090     /**
3091      * Use this function when a new node is added and keys need to be rehashed.
3092      */
3093     public function _rehash() {}
3094 }
View Code
原文地址:https://www.cnblogs.com/lhat/p/6402472.html