PHP中利用redis實現消息隊列處理高並發請求


將請求存入redis
 
為了模擬多個用戶的請求,使用一個for循環替代
 
//redis數據入隊操作
$redis = new Redis();
$redis->connect('127.0.0.1',6379);
for($i=0;$i<50;$i++){
    try{
        $redis->LPUSH('click',rand(1000,5000));
    }catch(Exception $e){
        echo $e->getMessage();
    }
}
 
 
 
 
在后台進行數據處理
 
守護進程
 
 
 
//redis數據出隊操作,從redis中將請求取出
$redis = new Redis();
$redis->pconnect('127.0.0.1',6379);
while(true){
    try{
        $value = $redis->LPOP('click');
        if(!$value){
            break;
        }
        //var_dump($value)."\n";
        /*
         *  利用$value進行邏輯和數據處理
         */
    }catch(Exception $e){
        echo $e->getMessage();
    }
}

  


免責聲明!

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



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