《PHP實戰:PHP基于Redis消息隊列實現發布微博的方法》要點:
本文介紹了PHP實戰:PHP基于Redis消息隊列實現發布微博的方法,希望對您有用。如果有疑問,可以聯系我們。
本文實例講述了PHP基于Redis消息隊列實現發布微博的方法.分享給大家供大家參考,具體如下:PHP編程
phpRedisAdmin :github地址? 圖形化管理界面PHP編程
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數據PHP編程
PHP編程
為了降低Mysql的并發數,先把用戶的微博存在Redis中PHP編程
假設用戶發布的時候需要三個字段,uid(用戶ID號),username(用戶姓名),content('用戶的評論')PHP編程
比如用戶傳遞以下信息PHP編程
//此處需要安裝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); ?>
PHP編程
此處可以看到我們的redis已經有數據了PHP編程
//創建一個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編程
更多關于PHP相關內容感興趣的讀者可查看本站專題:《php+redis數據庫程序設計技巧總結》、《PHP擴展開發教程》、《php+mysql數據庫操作入門教程》、《php+mysqli數據庫程序設計技巧總結》、《php面向對象程序設計入門教程》、《PHP網絡編程技巧總結》及《php常見數據庫操作技巧匯總》PHP編程
希望本文所述對大家PHP程序設計有所幫助.PHP編程
轉載請注明本頁網址:
http://www.snjht.com/jiaocheng/869.html