欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

PHP基于Redis消息隊列實現發(fā)布微博的方法

 更新時間:2017年05月03日 14:26:16   作者:yhdsir  
這篇文章主要介紹了PHP基于Redis消息隊列實現發(fā)布微博的方法,結合實例形式分析了php+redis數據庫的安裝、連接、讀取、插入等相關操作技巧,需要的朋友可以參考下

本文實例講述了PHP基于Redis消息隊列實現發(fā)布微博的方法。分享給大家供大家參考,具體如下:

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的并發(fā)數,先把用戶的微博存在Redis中

假設用戶發(fā)布的時候需要三個字段,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已經有數據了

//創(chuàng)建一個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擴展開發(fā)教程》、《php+mysql數據庫操作入門教程》、《php+mysqli數據庫程序設計技巧總結》、《php面向對象程序設計入門教程》、《PHP網絡編程技巧總結》及《php常見數據庫操作技巧匯總

希望本文所述對大家PHP程序設計有所幫助。

相關文章

最新評論