1.作为缓存
redis缓存使用get.set.setex缓存数据.setex语法:
//过期时间单位为s/秒
$redis->setex(key,过期时间/s,value);
应用场景实例:
//实例化redis
$redis = new \Redis();
//连接redis
$redis->connect(`127.0.0.1`,6379);
//选择数据库(数字为库的序号)
$redis->select(1);
//设置一个key
$key = 'key';
//获取redis中的value
$value = $redis->get($key);
//为空表示缓存过期或第一次访问
if(empty($value)){
//设置一个过期时间为10秒的数据
$redis->setex($key,10,1);
//执行你的业务代码
//...
}
2.作为消息队列
redis消息队列的思路是:
在遇到需要消耗大量时间的操作时间将操作需要的参数通过rpush()函数添加到redis队列,继续执行主业务.不影响业务的正常使用.
建立一个后台任务执行php脚本监听redis中rpush时的key,有新数据时则处理,无数据时死循环继续监听
具体实现:
/**
* 思路
* 将需要更新的pid存入redis
* 通过执行for循环的死循环脚本监听redis此key是否更新
* 有更新时执行更新
*/
$redis = new \Redis();
$redis->connect('127.0.0.1',6379);
$redis->select(5);
$update_team_num_key = 'update_team_num_key';
$redis->rpush($update_team_num_key,$data['pid']);
//继续执行主业务...
//...
//监听redis
//在php cli模式中执行监听
//在命令行中执行的方法(thinkphp)----php ./index.php /模块/控制器/方法
public function listenRedis(){
$redis = new \Redis();
$redis->connect('127.0.0.1',6379);
$redis->select(5);
$update_team_num_key = 'update_team_num_key';
echo '****************start listenRedis begin*******************';
while (true) {
if($redis->get('stop_team') == 1){
return;
}
//获取队列长度
$len = $redis->llen($update_team_num_key);
//判断长度是否为0
if($len){
//有需要更新的数据时取出pid
$pid = $redis->lpop($update_team_num_key);
//执行自动更新
$this->m->update_reg($pid);
$this->pidLevel($pid);
}
sleep(1);
}
echo 'stop listenRedis!';
}