把瞬間伺服器的請求處理換成非同步處理,緩解伺服器的壓力,實現數據順序排列獲取。本文主要和大家分享php和redis如何實現消息隊列,希望能幫助到大家。 redis實現消息隊列步驟如下: 1).redis函數rpush,lpop 2).建議定時任務入隊列 3)創建定時任務出隊列 文件:demo.php插 ...
把瞬間伺服器的請求處理換成非同步處理,緩解伺服器的壓力,實現數據順序排列獲取。本文主要和大家分享php和redis如何實現消息隊列,希望能幫助到大家。
redis實現消息隊列步驟如下:
1).redis函數rpush,lpop
2).建議定時任務入隊列
3)創建定時任務出隊列
文件:demo.php插入數據到redis隊列
<?php $redis = new Redis(); $redis->connect('127.0.0.1',6379); $password = '123456'; $redis->auth($password); $arr = array('h','e','l','l','o','w','o','r','l','d'); foreach($arr as $k=>$v){ $redis->rpush("mylist",$v); }
文件:index.php定時掃描出隊列
<?php $redis = new Redis(); $redis->connect('127.0.0.1',6379); $password = '123456'; $redis->auth($password); //list類型出隊操作 $value = $redis->lpop('mylist'); if($value){ echo "出隊的值".$value; }else{ echo "出隊完成"; } ?>
建立定時任務
*/1 * * * * root php /wwwroot/workplace/redis/index.php */3 * * * * root php /wwwroot/workplace/redis/demo.php tail -f /var/log/cron 查看定時任務執行情況 Nov 7 00:30:01 dongzi CROND[6888]: (root) CMD (php /wwwroot/workplace/redis/demo.php) Nov 7 00:30:01 dongzi CROND[6890]: (root) CMD (php /wwwroot/workplace/redis/index.php )
定時任務執行隊列寫入結果如下
127.0.0.1:6379> lrange mylist 0 -1 1) "h" 2) "e" 3) "l" 4) "l" 5) "o" 6) "w" 7) "o" 8) "r" 9) "l" 10) "d"
定時任務執行出隊列後:
127.0.0.1:6379> lrange mylist 0 -11) "e"2) "l"3) "l"4) "o"5) "w"6) "o"7) "r"8) "l"9) "d"
以上內容希望幫助到大家,很多PHPer在進階的時候總會遇到一些問題和瓶頸,業務代碼寫多了沒有方向感,不知道該從那裡入手去提升,對此我整理了一些資料,包括但不限於:分散式架構、高可擴展、高性能、高併發、伺服器性能調優、TP6,laravel,YII2,Redis,Swoole、Swoft、Kafka、Mysql優化、shell腳本、Docker、微服務、Nginx等多個知識點高級進階乾貨需要的可以免費分享給大家,需要的可以加入我的官方群點擊此處。