php结合redis高并发下发帖、发微博的实现方法
发帖、发微博、点赞、评论等这些操作很频繁的动作如果并发量小,直接入库是最简单的
但是并发量一大,数据库肯定扛不住,这时可采取延迟发布:先将发布动作保存在队列里,后台进程循环获取再入库
模拟发布微博先进入redis队列
weibo_redis.php
<?php
//此处需要安装phpredis扩展
$redis=newRedis();
$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
classPdodb{
publicfunctionpost($uid='',$username='',$content=''){
try{
$dsn="mysql:localhost;dbname=localhost;dbname=big";
$db=newPDO($dsn,'big','123456');
$db->exec("SETNAMESUTF8");
$sql="insertintoih_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=newPdodb();
$redis=newRedis();
$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
nohupphp/var/www/html/big/weibo_mysql.php&
以上这篇php结合redis高并发下发帖、发微博的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。