ThinkPHP5中如何使用redis

目录
  • 配置
  • redis使用
    • string(字符串)
    • Hash(哈希)
    • List(列表)
    • Set(集合)
    • zset(有序集合)
  • 总结

前提:因为本文主要围绕着在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

	/**
     * 返回句柄对象,可执行其它高级方法
     *
     * @access public
     * @return object
     */
    public function handler()
    {
        return $this->handler;
    }
	/*
    *  获取句柄
    * @param
    */
    public static function getHandler()
    {
        return self::init();
    }

redis使用

string(字符串)

基本的类型,一个 key 对应一个 value。

一个string 类型的值最大能存储 512MB

图解:

// 创建数据
$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多亿)

图解 :

// 创建 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多亿)。

图解 :

// 向队列左侧加入元素
$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)。

图解 :

// 创建集合
$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正是通过分数来为集合中的成员进行从小到大的排序。

// 添加成员
$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);

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • thinkphp5redis缓存新增方法实例讲解

    找到该文件 thinkphp/library/think/cache/driver/Redis.php 进行新增方法 在这里 我就举例几个 如何添加 添加的方法查看 redis教程 /** * 返回列表中指定区间内的元素 * */ public function lrange($key,$start,$end){ return $this->handler->lrange($key,$start,$end); } /** * 在list左边新增元素 * */ public function l

  • thinkphp5 操作redis 实现文章的热度排行和点赞排行的示例

    使用redis hash散列 和zset有序集合实现文章的热度排行和点赞排行 1.首先为文章建立散列,存入基本信息. mysql简单设计 获取所有文章,并存入redis //所有新闻页 public function news() { $redis = new Redis(); $list = News::select(); foreach ($list as &$row){ //将所有数据存到hash散列里,用于显示简介信息 $redis->handler()->hmset('new

  • thinkphp5框架扩展redis类方法示例

    本文实例讲述了thinkphp5框架扩展redis类方法.分享给大家供大家参考,具体如下: 笔者在开发时发现,thinkphp5的自带redis类方法,只有简单的读取缓存.写入缓存的基本方法,远不能满足我们业务的需求.redis本身支持五种数据类型,string(字符串).hash(哈希).list(列表).set(集合).zset(有序集合).redis的东西就不必再介绍了,接下来还是让我一起扩展thinkphp5的redis方法吧! 首先我们先找到缓存驱动类里的,handler()方法,这个

  • Thinkphp5+Redis实现商品秒杀代码实例讲解

    环境:wamp,redis 要求:安装WAMP,Redis,以及为PHP安装Redis扩展 秒杀功能大致思路:获取缓存列表的长度,如果长度(llen)等于0,就停止秒杀,即秒杀失败,如果长度大于0,则继续运行,先从缓存中移除一个元素(lpop),再进行数据库操作(添加订单表,商品库存数量减一),如果再进一个人秒杀,就再走一遍流程,循环往复. 一.安装Redis扩展 1.查看PHP版本信息 打开phpinfo.php,查看PHP版本,我的是PHP7.3.4,还有一个需要注意Architecture

  • ThinkPHP5中如何使用redis

    目录 配置 redis使用 string(字符串) Hash(哈希) List(列表) Set(集合) zset(有序集合) 总结 前提:因为本文主要围绕着在thinkPHP5中使用redis的,所以关于redis的安装就不特意说明了,不过在这稍微提醒一下,安装完redis后务必要开启php.ini扩展,否则还是无法使用redis的. 配置 1.会用ThinkPHP5的同学们都知道,TinkPHP5中封装了缓存类,我们只需要在/application/congfig.php中的cache中填入缓

  • 如何在 Java 中实现一个 redis 缓存服务

    缓存服务的意义 为什么要使用缓存?说到底是为了提高系统的运行速度.将用户频繁访问的内容存放在离用户最近,访问速度最快的地方,提高用户的响应速度.一个 web 应用的简单结构如下图. web 应用典型架构 在这个结构中,用户的请求通过用户层来到业务层,业务层在从数据层获取数据,返回给用户层.在用户量小,数据量不太大的情况下,这个系统运行得很顺畅.但是随着用户量越来越大,数据库中的数据越来越多,系统的用户响应速度就越来越慢.系统的瓶颈一般都在数据库访问上.这个时候可能会将上面的架构改成下面的来缓解数

  • C#中如何使用redis

    redis 是一个非关系型高性能的key-value数据库.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sorted set --有序集合)和hash(哈希类型).这些数据类型都支持push/pop.add/remove及取交集并集和差集及更丰富的操作,而且这些操作都是原子性的.在此基础上,redis支持各种不同方式的排序.与memcached一样,为了保证效率,数据都是缓存在内存中.区别的是redis会周

  • Spring项目中使用Cache Redis实现数据缓存

    目录 Spring项目中实现数据缓存 一.Spring Cache + Redis 介绍 二.项目中集成 1. 引入依赖 2. 添加 redis 配置类 3. 配置文件增加 redis 配置 4. 启动安装好的 redis 三.Spring Cache 常用注解介绍 1. @Cacheable 2. @CachePut 3. @CacheEvict 四.功能里实现缓存操作 查询操作 导入操作 Spring项目中实现数据缓存 有时候我们为了提高查询速度,会使用缓存,但是并不是所有数据都适合放到缓存

  • spring boot中内嵌redis的使用方法示例

    redis介绍 Redis是目前业界使用最广泛的内存数据存储.相比memcached,Redis支持更丰富的数据结构,例如hashes, lists, sets等,同时支持数据持久化.除此之外,Redis还提供一些类数据库的特性,比如事务,HA,主从库.可以说Redis兼具了缓存系统和数据库的一些特性,因此有着丰富的应用场景. 引言 对于单元测试来说,我们应该让它尽量保持单一环境,不要与网络资源相通讯,这样可以保证测试的稳定性与客观性,对于springboot这个框架来说,它集成了单元测试JUN

  • PHP中如何使用Redis接管文件存储Session详解

    前言 php默认使用文件存储session,如果并发量大,效率会非常低.而redis对高并发的支持非常好,可以利用redis替换文件来存储session. 最近就遇到了这个问题,之前找了网上的一套直播系统给客户用,刚开始是没问题的,在后面人数上来之后网站开始变得卡顿,卡的一批.之后查看php慢日志发现session_start()的身影,好吧,原来是万恶的文件存储session,跟我之前进的坑一模一样--之前做的教务查询系统直接用的session没有用cookie,结果在高并发的情况下php原地

  • php在linux环境中如何使用redis详解

    1.php安装. 2.下载redis并编译(最好是在 /usr/local目录下运行该命令) # wget http://download.redis.io/releases/redis-6.0.8.tar.gz # tar xzf redis-6.0.8.tar.gz # cd redis-6.0.8 # make 3.完成后进入src目录运行redis # cd src # ./redis-server 如果运行成功,会出现redis图片,以及必要信息提示成功. 服务器规则组打开6379端口

  • 了解redis中RDB结构_动力节点Java学院整理

    RDB文件是在redis的"快照"的模式下才会产生,那么如果我们理解了RDB文件的结构,是不是让我们对"快照"模式能做到一个心中有数呢??? 一.RDB结构剖析 首先呢,我们要对RDB文件有一个概念性的认识,比如下面画的图一样: 从图中,我们大概看到了RDB文件的一个简要的存储模式,但为了更好的方便对照,我准备save一个empty database,对比一下看看效果: 然后我们用winHex打开dump.rdb文件,看看它的16进制. 好了,该打开的我都打开了,下

  • 详解.NET中使用Redis数据库

    Redis是一个用的比较广泛的Key/Value的内存数据库,新浪微博.Github.StackOverflow 等大型应用中都用其作为缓存,Redis的官网为http://redis.io/. 最近项目中需要使用Redis,这里简单记录一下Redis的安装,以及如何在.NET中使用Redis. Redis安装与启动 1. 下载Redis Redis本身没有提供Windows版本的,并且在Windows上也不太稳定,一般都将其部署到Linux环境下,Redis可以在其官网上下载, MSOpenT

  • php+redis在实际项目中HTTP 500: Internal Server Error故障排除

    问题描述 用户量快速增长,访问量在短时间内翻倍,由于前期容量规划做得比较好,硬件资源可以支撑,可是软件系统方面出现了大问题: 40% 的请求都会返回 HTTP 500: Internal Server Error 通过查看日志,发现错误是在 PHP <-> Redis 的连接处理上 调试处理 第1次 刚开始时并没有找到根本原因,只能尝试各种与错误相关的办法,例如: 增加 PHP 连接数,并把超时时间从 500ms 增加到 2.5s 禁止掉 PHP 设置中的 default_socket_tim

随机推荐