程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> php結合redis高並發下發帖、發微博的實現方法,redis發微

php結合redis高並發下發帖、發微博的實現方法,redis發微

編輯:關於PHP編程

php結合redis高並發下發帖、發微博的實現方法,redis發微


發帖、發微博、點贊、評論等這些操作很頻繁的動作如果並發量小,直接入庫是最簡單的

但是並發量一大,數據庫肯定扛不住,這時可采取延遲發布:先將發布動作保存在隊列裡,後台進程循環獲取再入庫

模擬發布微博先進入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高並發下發帖、發微博的實現方法就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持幫客之家。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved