發帖、發微博、點贊、評論等這些操作很頻繁的動作如果並發量小,直接入庫是最簡單的
但是並發量一大,數據庫肯定扛不住,這時可采取延遲發布:先將發布動作保存在隊列裡,後台進程循環獲取再入庫
模擬發布微博先進入redis隊列
weibo_redis.php
<?php //此處需要安裝phpredis擴展 $redis = new Redis(); $redis->connect('127.0.0.1', 6379); $redis->auth("php001"); //連接redis $web_info= array( 'uid' => $_REQUEST[uid], //發布者id 'username' => $_REQUEST[username],//發布者用戶名 'content' =>$_REQUEST[content],//微博內容 ); //將數組轉成json來存儲 $list = json_encode($web_info); //lpush向KEY對應的頭部添加一個字符串元素 $redis->lpush('weibo_lists',$list); $redis->close(); var_dump($list); ?>
模擬後台進程從redis隊列獲取微博
Pdodb.class.php
<?php class Pdodb{ public function post($uid='',$username='',$content=''){ try{ $dsn = "mysql:localhost;dbname=localhost;dbname=big"; $db = new PDO($dsn,'big','123456'); $db->exec("SET NAMES UTF8"); $sql ="insert into ih_weibo(uid,username,content)values('$uid','$username','$content')"; //echo $sql; $db->exec($sql); }catch(PDOException $e){ echo $e->getMessage(); } } }
weibo_mysql.php
<?php require_once 'Pdodb.class.php'; set_time_limit(0); // 取消腳本運行時間的超時上限 $pdo = new Pdodb(); $redis = new Redis(); $redis->connect('127.0.0.1', 6379); while (true) { //返回的列表的大小。如果列表不存在或為空,該命令返回0。如果該鍵不是列表,該命令返回false if($redis -> lsize('weibo_lists')){ //從LIST頭部刪除並返回刪除數據 $info = $redis->rpop('weibo_lists'); $info = json_decode($info); $pdo->post($info->uid,$info->username,$info->content); } $redis->close(); sleep(10);//延時10秒 }
後台執行weibo_mysql.php
nohup php /var/www/html/big/weibo_mysql.php &
以上這篇php結合redis高並發下發帖、發微博的實現方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持。