文章主要介紹了php基于Redis消息隊列實現的消息推送的方法,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
基本知識點
重點用到了以下命令實現我們的消息推送
- brpop 阻塞模式 從隊列右邊獲取值之后刪除
- brpoplpush 從隊列A的右邊取值之后刪除,從左側放置到隊列B中
邏輯分析
- 在普通的任務腳本中寫入push_queue隊列要發送消息的目標,并為目標設置一個要推送的內容,永不過期
- RedisPushQueue中brpoplpush處理,處理后的值放到temp_queue,主要防止程序崩潰造成推送失敗
- RedisAutoDeleteTempqueueItems處理temp_queue,這里用到了brpop
代碼實現
普通任務腳本
<?phpforeach($user_listas$item) {//命名規則 業務類型_操作_ID_隨機6位 值 自定義 我自定義的是"推送內容"$k_name='rabbit_push_'.$item['uid'].'_'.rand(100000,999999);$redis->lPush('push_queue',$k_name);//左進隊列$redis->set($k_name,'推送內容');}
RedisPushQueue
<?php//消息隊列處理推送~//// 守護進程運行// nohup php YOURPATH/RedisPushQueue.php & 開啟守護進程運行,修改文件之后需要從新啟動// blpop 有值則回去 沒值則阻塞 主要就是這個函數在起作用 不過并不安全,程序在執行過程中崩潰就會導致隊列中的內容// 永久丟失~// BRPOPLPUSH 阻塞模式 右邊出 左邊進 在填寫隊列內容的時候要求從左進入//ini_set('default_socket_timeout', -1);//不超時require_once'YOURPARH/Rongcloud.php';$redis=new\Redis();$redis->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
<?php/* 自動處理temp_queue中的元素,這個操作是防止RedisPushQueue崩潰的時候做處理處理思路是 使用brpop 命令阻塞處理temp_queue這個隊列中的值,如果能獲取到"值"對應的"值",說明RedisPushQueue執行失敗了將值還lpush到push_queue中,以備從新處理至于為什么使用brpop命令,是因為在RedisPushQueue中我們使用的是brpoplpushnohup php YOURPATH/RedisAutoDeleteTempqueueItems.php & 開啟守護進程運行,修改文件之后需要從新啟動*/ini_set('default_socket_timeout', -1);//不超時$redis=new\Redis();$redis->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);}}
以上就是PHP基于Redis消息隊列實現的消息推送的方法的全部內容,希望對大家的學習有所幫助。
分享到:
投訴收藏














