php基于Redis消息队列实现的消息推送的方法
基本知识点
重点用到了以下命令实现我们的消息推送
- brpop阻塞模式从队列右边获取值之后删除
- brpoplpush从队列A的右边取值之后删除,从左侧放置到队列B中
逻辑分析
- 在普通的任务脚本中写入push_queue队列要发送消息的目标,并为目标设置一个要推送的内容,永不过期
- RedisPushQueue中brpoplpush处理,处理后的值放到temp_queue,主要防止程序崩溃造成推送失败
- RedisAutoDeleteTempqueueItems处理temp_queue,这里用到了brpop
代码实现
普通任务脚本
lPush('push_queue',$k_name);//左进队列
$redis->set($k_name,'推送内容');
}
RedisPushQueue
connect('127.0.0.1',6379);
$redis->select(2);//切换到db2
$redis->setOption(\Redis::OPT_READ_TIMEOUT,-1);
//temp_queue临时队列防止程序崩溃导致队列中内容丢失0代表永不超时!
While($key=$redis->brpoplpush('push_queue','temp_queue',0)){
if($val=$redis->get($key)){
//rabbit_push_20_175990
$arr=explode('_',$key);
if(count($arr)!=4){
continue;
}
$id=$arr[2];
push($id,$val);
//删除key内容
$redis->del($key);
}
}
functionpush($id,$v)
{
//推送操作~
}
RedisAutoDeleteTempqueueItems
connect('127.0.0.1',6379);
$redis->select(2);//切换到db2
$redis->setOption(\Redis::OPT_READ_TIMEOUT,-1);
while($key_arr=$redis->brPop('temp_queue',0)){
if(count($key_arr)!=2){
continue;
}
$key=$key_arr[1];
if($redis->get($key)){//能获取到值说明RedisPushQueue执行失败
$redis->lPush('push_queue',$key);
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。