Redis 简单使用
简单操作
比如显示给定用户的配置文件。
$user = Redis::get('user:profile:'.$id);
Redis::set('user:profile:'.$id, "ok");
你可以在 Redis
上调用任何的 Redis
命令。Swoft
使用魔术方法将传递命令给 Redis
服务器,因此只需传递 Redis 命令所需的参数即可:
Redis::set('name', 'Taylor');
$values = Redis::lrange('names', 5, 10);
所有方法和 操作 phpredis
原生一样 本质是通过魔术方法代理访问的,让操作变得更简单
当然普通的字符串设置不能满足我们的日常开发,你也可以使用 数组的方式
$setData = [
'goods' => [
'goods_id' => 1,
'goods_name' => 'iPhone xx'
]
];
Redis::set($key, $setData);
通过 get 方法 调用,底层会自动反序列化,保证了存进去,取出来的数据一致性。
指定连接池获取连接
当然 所有的连接都是在连接池中分配的 如果你想使用自己定义的连接可以使用
$poolName = 'redis-clusters-pool'
$redis = Redis::connection($poolName);
$redis->get("a");
获取的连接了之后和 操作 和phpredis
原生使用方式扩展一致 如何创建连接池 参考 redis 设置
章节
,默认是在 redis.pool
连接池中获取的
缓存命中率
如果你想看一个 key
获取的命中情况,可以在你的notice
日志级别中获取,格式大致是 redis.hit/req....
这样的前缀,有助于你分析缓存命中率。
事件监听
before 事件
在Redis
执行之前底层会抛出 RedisEvent::BEFORE_COMMAND
事件
<?php declare(strict_types=1);
namespace App\Listener;
use Swoft\Event\Annotation\Mapping\Listener;
use Swoft\Event\EventHandlerInterface;
use Swoft\Event\EventInterface;
use Swoft\Redis\RedisEvent;
/**
* Class FinishListener
*
* @since 2.0
*
* @Listener(event=RedisEvent::BEFORE_COMMAND)
*/
class RedisBeforeListener implements EventHandlerInterface
{
/**
* @param EventInterface $event
*/
public function handle(EventInterface $event): void
{
[$method, $parameters] = $event->getParams();
}
}
after 事件
在 Redis
命令之后会抛出 RedisEvent::AFTER_COMMAND
事件 你可以监听命令的执行情况,如果在执行命令中出现异常 不会抛出 RedisEvent::AFTER_COMMAND
事件
<?php declare(strict_types=1);
namespace App\Listener;
use Swoft\Event\Annotation\Mapping\Listener;
use Swoft\Event\EventHandlerInterface;
use Swoft\Event\EventInterface;
use Swoft\Redis\RedisEvent;
/**
* Class FinishListener
*
* @since 2.0
*
* @Listener(event=RedisEvent::AFTER_COMMAND)
*/
class RedisAfterListener implements EventHandlerInterface
{
/**
* @param EventInterface $event
*/
public function handle(EventInterface $event): void
{
[$method, $parameters, $result] = $event->getParams();
}
}