前提:因为本文主要围绕着在thinkPHP5中使用redis的,所以关于redis的安装就不特意说明了,不过在这稍微提醒一下,安装完redis后务必要开启php.ini扩展,否则还是无法使用redis的。
配置
1.会用ThinkPHP5的同学们都知道,TinkPHP5中封装了缓存类,我们只需要在/application/congfig.php中的cache中填入缓存配置项就可以使用了(如下所示)。
2.从/thinkphp/library/think/cache/driver/Redis.php文件可知这里封装的redis缓存只能使用redis的string基本类型,如果要使用哈希或队列等复合数据类型的话是不行的。
看缓存类/thinkphp/library/think/cache/Driver.php会发现handler方法会返回句柄,所以我们只要在我们使用redis的地方获得这个句柄就可以使用redis的所有数据类型了,因此可以在/thinkphp/library/think/Cache.php中添加获取句柄方法getHandler
1 2 3 4 5 6 7 8 9 10 | /** * 返回句柄对象,可执行其它高级方法 * * @access public * @return object */ public function handler() { return $this ->handler; } |
1 2 3 4 5 6 7 8 | /* * 获取句柄 * @param */ public static function getHandler() { return self::init(); } |
redis使用
string(字符串)
基本的类型,一个 key 对应一个 value。
一个string 类型的值最大能存储 512MB
图解:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | // 创建数据 $redis ->set( 'key' , 'value' ); // 获取数据 $value = $redis ->get( 'key' ); echo $value . PHP_EOL; // 修改数据,与创建数据一致,即覆盖数据 $redis ->set( 'key' , 'value2' ); echo $redis ->get( 'key' ) . PHP_EOL; // 追加数据 $redis ->append( 'key' , '_value2' ); echo $redis ->get( 'key' ) . PHP_EOL; // 删除数据 $redis ->del( 'key' ); // $redis->delete('key'); var_dump( $redis ->get( 'key' )); // 创建数据,带有效期 $redis ->set( 'timeout_key' , 'timeout_value' , 5); $redis ->setex( 'timeout_key' , 5, 'timeout_value' ); // 获取数据的有效期 echo $redis ->ttl( 'timeout_key' ) . PHP_EOL; // 判断是否已经写入,未写入则写入 $redis ->set( 'unique_key' , 'unique_value' ); if (! $redis ->setnx( 'unique_key' , 'unique_value' )) { echo $redis ->get( 'unique_key' ) . PHP_EOL; } // 批量创建 $multi = [ 'key1' => 'value1' , 'key2' => 'value2' , 'key3' => 'value3' ]; $redis ->mset( $multi ); // 批量获取 $result = $redis ->mget( array_keys ( $multi )); var_dump( $result ); |
Hash(哈希)
hash 是一个键值(key=>value)对集合;是一个 string 类型的 field 和 value 的映射表,hash 特别适合用于存储对象。
每个 hash 可以存储 2^32 -1 键值对(40多亿)
图解 :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | // 创建 hash 表 // 向名字叫 'hash' 的 hash表 中添加元素 ['key1' => 'val1'] $redis ->hSet( 'hash' , 'key1' , 'val1' ); // 获取 hash表 中键名是 key1 的值 echo $redis ->hGet( 'hash' , 'key1' ) . PHP_EOL; // 获取 hash表的元素个数 echo $redis ->hLen( 'hash' ) . PHP_EOL; // 获取 hash表 中所有的键 $keys = $redis ->hKeys( 'hash' ); var_dump( $keys ); // 获取 hash表 中所有的值 $vals = $redis ->hVals( 'hash' ); var_dump( $vals ); // 获取 hash表 中所有的键值对 // 不推荐使用这种方法获取全部数据,会导致服务器执行超时,推荐方法后边会详细介绍 // $all = $redis->hGetAll('hash'); // var_dump($all);// 判断 hash 表中是否存在键名是 key2 的元素 $bool = $redis ->hExists( 'hash' , 'key2' ); echo $bool ? '存在' : '不存在' . PHP_EOL; // 批量添加元素 $redis ->hMset( 'hash' , [ 'key2' => 'val2' , 'key3' => 'val3' ]); // 批量获取元素 $hashes = $redis ->hMGet( 'hash' , [ 'key1' , 'key2' , 'key3' ]); var_dump( $hashes ); // 删除 hash表 $redis ->del( 'hash' ); |
List(列表)
列表是简单的字符串列表,按照插入顺序排序。你可以添加一个元素到列表的头部(左边)或者尾部(右边)。list类型经常会被用于消息队列的服务,以完成多程序之间的消息交换。列表最多可存储 2^32 – 1 元素 (4294967295, 每个列表可存储40多亿)。
图解 :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 | // 向队列左侧加入元素 $redis ->lPush( 'lists' , 'X' ); $redis ->lPush( 'lists' , 'X' ); // 向队列右侧加入元素 $redis ->rPush( 'lists' , 'Z' ); // 将索引为1的数据修改为 Y $redis ->lSet( 'lists' , 1, 'Y' ); // 获取 list 长度 $length = $redis ->lLen( 'lists' ); echo $length ; // 遍历 list $lists = $redis ->lRange( 'lists' , 0, $length - 1); dump( $lists ); // 从左侧出队一个元素(获取并删除) $x = $redis ->lPop( 'lists' ); echo $x . PHP_EOL; // 从右侧出队一个元素(获取并删除) $z = $redis ->rPop( 'lists' ); echo $z . PHP_EOL; // 获取左侧第一个元素 $y = $redis ->lIndex( 'lists' , 0); echo $y . PHP_EOL; // 删除队列 $redis ->del( 'lists' ); |
Set(集合)
Redis的Set是string类型的无序集合。
和列表一样,在执行插入和删除和判断是否存在某元素时,效率是很高的。
集合最大的优势在于可以进行交集并集差集操作。
Set可包含的最大元素数量是4294967295(40多亿)。
集合是通过哈希表实现的,所以添加,删除,查找的复杂度都是O(1)。
图解 :
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | // 创建集合 $redis ->sAdd( 'sets' , 'value1' , 'value2' ); // 以数组形式创建集合 $redis ->sAddArray( 'sets2' , [ 'value1' , 'value2' , 'value3' ]); // 取两个集合的并集 $union = $redis ->sUnion( 'sets' , 'sets2' ); // 取两个集合的差集 $diff = $redis ->sDiff( 'sets' , 'sets2' ); // 取两个集合的交集 $inter = $redis ->sInter( 'sets' , 'sets2' );var_dump( $union , $diff , $inter ); // 获取集合数量 $card = $redis ->sCard( 'sets' ); echo $card . PHP_EOL; // 获取集合中全部元素 // 不推荐使用这种方法获取全部数据,会导致服务器执行超时,推荐方法后边会详细介绍 $sets = $redis ->sMembers( 'sets' ); var_dump( $sets ); // 判断元素是否是集合中的成员 $isMember = $redis ->sIsMember( 'sets' , 'value2' ); var_dump( $isMember ); // 删除集合中的元素 $redis ->sRem( 'sets' , 'value2' ); var_dump( $redis ->sMembers( 'sets' )); // 随机获取一个元素 echo $redis ->sRandMember( 'sets' ); // 随机获取一个元素并从集合中删除 echo $redis ->sPop( 'sets' ); // 删除集合 $redis ->del( 'sets' , 'sets2' ); |
zset(有序集合)
Redis zset 和 set 一样也是string类型元素的集合,且不允许重复的成员。
不同的是每个元素都会关联一个double类型的分数。
redis正是通过分数来为集合中的成员进行从小到大的排序。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | // 添加成员 $redis ->zAdd( 'zset' , 95, '小明' ); $redis ->zAdd( 'zset' , 99, '小刚' ); $redis ->zAdd( 'zset' , 100, '小红' ); // 统计成员个数 echo $redis ->zCard( 'zset' ) . PHP_EOL; // 获取某个成员的分数 $score = $redis ->zScore( 'zset' , '小明' ); echo $score . PHP_EOL; // 获取某个成员的排名 $rank = $redis ->zRank( 'zset' , '小明' ); // 从低到高排序的名次 $revRank = $redis ->zRevRank( 'zset' , '小明' ); // 从高到低排序的名次 echo $rank . PHP_EOL; echo $revRank . PHP_EOL; // 给指定成员增加分数 $redis ->zIncrBy( 'zset' , 1, '小明' ); // 给小明加一分// 返回指定排名范围的成员 $range = $redis ->zRange( 'zset' , 0, 9, true); // 返回分数从低到高排序的前10名及分数 $revRange = $redis -> zRevRange( 'zset' , 0, 9, true); // 返回分数从高到低排序的前10名及分数 var_dump( $range ); var_dump( $revRange ); // 删除成员 $redis ->zRem( 'zet' , '小明' ); // 返回指定分数范围的成员 $rangeByScore = $redis ->zRangeByScore( 'zet' , 98, 100); // 返回指定分数范围内从低到高排序的成员 $revRangeByScore = $redis ->zRevRangeByScore( 'zet' , 98, 100); // 返回指定分数范围内从高到低排序的成员 var_dump( $rangeByScore ); var_dump( $revRangeByScore ); |
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持IT俱乐部。