php+redis實現消息隊列


php+redis消息隊列是php+mysql性能不足時的一個中間間處理方案。通過這個中間的處理,保證的數據的可用性和准確性。用於服務器瞬間請求大,數據庫壓力大的情況。如並發量大導致的超賣、並發量大導致的數據重復情況。

        流程:php接受請求和數據 -> php把數據寫入redis隊列中(入隊) -> shell定時調用php讀取隊列數據寫入mysql(出隊)

 

        實現代碼:

 

入隊:inqueue.php

<?php
$redis = new redis();
$redis->connect('127.0.0.1',6379);
$redis -> select('1');
$redis->auth('');
 
$data = [a,b,c,d,e,f,g,h]; //這里可以是get或post請求過來的數據
$data = json_encode($data);
$in = $redis->rpush('queue',$data);
if($in){
    echo "入隊成功";
}

  

出隊:outqueue.php

#!/usr/bin/php
<?php
$redis = new redis();
$redis->connect('127.0.0.1',6379);
$redis -> select('1');
$redis->auth('');
 
$value = $redis->lpop('queue');
$value = json_decode($value,true);

  

 

shell process.sh:定時調用outqueue.php腳本

#進行每分鍾調用一次
* * * * * /usr/local/nginx/html/process.sh
#!/bin/bash
#file_name : process.sh
#author : zuoping
php /usr/local/nginx/html/outqueue.php

  

*如果每分鍾調用一次頻率不夠,可以執行多次調用腳本,如:

#!/bin/bash
#file_name : process.sh
#author : zuoping
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
php /usr/local/nginx/html/outqueue.php
#這樣就一分鍾調用了多次了。

 

查看隊列中的當前數據:

<?php
$redis = new redis();
$redis->connect('127.0.0.1',6379);
$redis -> select('1');
$redis->auth('');
 
$list = $redis->lrange('queue',0,-1);
var_dump($list);

  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM