本文實例講述了PHP基于Redis消息隊列實現發布微博的方法。分享給大家供大家參考,具體如下:
phpRedisAdmin :github地址 圖形化管理界面
git clone [url]https://github.com/ErikDubbelboer/phpRedisAdmin.git[/url] cd phpRedisAdmin git clone [url]https://github.com/nrk/predis.git[/url] vendor
首先安裝上述的Redis圖形化管理界面,能夠方便的管理Redis數據
為了降低Mysql的并發數,先把用戶的微博存在Redis中
假設用戶發布的時候需要三個字段,uid(用戶ID號),username(用戶姓名),content('用戶的評論')
比如用戶傳遞以下信息
//此處需要安裝phpredis $redis = new Redis(); $redis->connect('127.0.0.1', 6379); // 連接redis $web_info= array( 'uid' => '123456', 'username' => '123', 'content' =>'123' ); //將數組轉成json來存儲 $list = json_encode($web_info); //lpush向KEY對應的頭部添加一個字符串元素 $redis->lpush('weibo_lists',$list); $redis->close(); ///var_dump(json_encode($web_info)); var_dump($list); ?>
此處可以看到我們的redis已經有數據了
//創建一個PDO數據庫鏈接 data.php class qq{ public function post($uid='',$username='',$content=''){ try{ $dsn = "mysql:host;dbname=localhost;dbname=test"; $db = new PDO($dsn,'root','root'); $db->exec("SET NAMES UTF8"); $sql ="insert into test(uid,username,content)values('$uid','$username','$content')"; $db->exec($sql); }catch(PDOException $e){ $e->getMessage(); } } }
//處理redis數據庫的數據 并把數據放到MYSQL數據庫中 include "data.php"; $qq = new qq(); $redis = new Redis(); $redis->connect('127.0.0.1', 6379); //返回的列表的大小。如果列表不存在或為空,該命令返回0。如果該鍵不是列表,該命令返回FALSE if($redis -> lsize('weibo_lists')){ //從LIST頭部刪除并返回刪除數據 $info = $redis->rPop('weibo_lists'); $info = json_decode($info); $qq->post($info->uid,$info->username,$info->content); } $redis->close(); var_dump($info); ?>
我們能看到數據庫已經有數據了
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php+redis數據庫程序設計技巧總結》、《PHP擴展開發教程》、《php+mysql數據庫操作入門教程》、《php+mysqli數據庫程序設計技巧總結》、《php面向對象程序設計入門教程》、《PHP網絡編程技巧總結》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
【網站聲明】本站除付費源碼經過測試外,其他素材未做測試,不保證完整性,網站上部分源碼僅限學習交流,請勿用于商業用途。如損害你的權益請聯系客服QQ:2655101040 給予處理,謝謝支持。