PHP+redis實(shí)現(xiàn)微博的推模型案例分析
本文實(shí)例講述了PHP+redis實(shí)現(xiàn)微博的推模型。分享給大家供大家參考,具體如下:
最近在看了一下關(guān)于redis的內(nèi)容,然后利用redis寫了一個(gè)簡(jiǎn)單的微博項(xiàng)目,這篇文章是關(guān)于推模型的。
推模型
所謂推模型,就是用戶在發(fā)布微博的時(shí)候會(huì)將微博推送給關(guān)注者和自己,然后其他關(guān)注者登錄之后就可以看到發(fā)布的微博。
微博項(xiàng)目數(shù)據(jù)結(jié)構(gòu)設(shè)計(jì)
user表設(shè)計(jì)
注冊(cè)的時(shí)候?qū)ser數(shù)據(jù)寫入redis中,key如下:
user數(shù)據(jù)的key
用戶名=user:uesrid:$uesrid:username
密碼=user:userid:$userid:password
還需要這樣寫一份,因?yàn)樾枰坑脩裘麃?lái)登錄,這樣就可以根據(jù)用戶名來(lái)查詢用戶id。
user:username:userid:$userid
關(guān)注的人和粉絲設(shè)計(jì)
每個(gè)用戶在產(chǎn)生關(guān)注的動(dòng)作后,在redis中維護(hù)兩個(gè)無(wú)序集合set,一個(gè)是following,一個(gè)是follower,following集合保存的是我關(guān)注的人,follower集合保存的是我的粉絲。注意是每個(gè)用戶都要維護(hù)這樣的兩個(gè)集合,用userid來(lái)區(qū)。
微博表設(shè)計(jì)
每條微博的信息用hash結(jié)構(gòu)來(lái)存儲(chǔ),根據(jù)不同的微博id來(lái)區(qū)分,每條微博有如下信息:發(fā)布人id,發(fā)布人昵稱,發(fā)布時(shí)間,微博內(nèi)容。
推送表設(shè)計(jì)
用戶在發(fā)布微博的時(shí)候,將微博推送給自己的粉絲,每個(gè)粉絲都維護(hù)一個(gè)推送微博的鏈表,這個(gè)鏈表只保存50條最新微博。推送表中保存的是微博id.
關(guān)注操作
我們?cè)趓edis中維護(hù)兩個(gè)無(wú)序集合set,一個(gè)是following,一個(gè)是follower,following集合保存的是我關(guān)注的人,follower集合保存的是我的粉絲。注意是每個(gè)用戶都要維護(hù)這樣的兩個(gè)集合,用userid來(lái)區(qū)分。
核心代碼:
$conn = connredis();//連接redis
if($f){//如果沒有關(guān)注過
$conn->sadd('following:'.$user['userid'],$userid);
$conn->sadd('follower:'.$userid,$user['userid']);
}else{
$conn->srem('following:'.$user['userid'],$userid);
$conn->srem('follower:'.$userid,$user['userid']);
}
發(fā)布微博
遍歷自己的粉絲,給每個(gè)粉絲都推送一條微博,將推送的微博保存到每個(gè)用戶的推送表中
核心代碼:
//1、保存微博
$conn = connredis();//連接redis
$postid = $conn->incr('global:postid');//生成微博id
//保存微博數(shù)據(jù)
$conn->hmset('post:postid:'.$postid,['userid'=>$user['userid'],'username'=>$user['username'],'time'=>time(),'content'=>$content]);
//2、推送微博
$fans = $conn->smembers('follower:'.$user['userid']);//獲取所有粉絲
$fans[] = $user['userid'];//自己也要推送一份
foreach($fans as $u){
$conn->lpush('receivepost:'.$u,$postid);
$conn->ltrim('receivepost:'.$u,0,49);//每個(gè)人保存最新微博50條
}
展示微博
首先連接redis,然后獲取自己的推送表的信息,遍歷推送表,然后獲取微博內(nèi)容,最后獲取自己的粉絲和關(guān)注數(shù)。進(jìn)行數(shù)據(jù)展示即可。
//獲取推送的微博id
$conn = connredis();
$postids = $conn->sort('receivepost:'.$user['userid'],['sort'=>'desc']);
//獲取微博
$posts = [];
foreach($postids as $postid){
$posts[] = $conn->hmget('post:postid:'.$postid,['userid','username','time','content']);
}
//獲取粉絲和關(guān)注數(shù)
$fansnum = $conn->scard('follower:'.$user['userid']);
$follownum = $conn->scard('following:'.$user['userid']);
總結(jié)
推模型的微博實(shí)例,實(shí)現(xiàn)還是比較簡(jiǎn)單的,但是推模型對(duì)性能有影響,假如我是一個(gè)大V,微博關(guān)注數(shù)有2000W,我在發(fā)微博的時(shí)候需要給2000W個(gè)人推送一條微博,但是很多人又是僵尸粉,可想而知對(duì)性能有一定的影響。我很可以將推模型改為拉模型,這樣就能解決這個(gè)問題了。
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《php+redis數(shù)據(jù)庫(kù)程序設(shè)計(jì)技巧總結(jié)》、《php面向?qū)ο蟪绦蛟O(shè)計(jì)入門教程》、《PHP基本語(yǔ)法入門教程》、《PHP數(shù)組(Array)操作技巧大全》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- PHP實(shí)現(xiàn)發(fā)送微博消息功能完整示例
- redis+php實(shí)現(xiàn)微博(三)微博列表功能詳解
- redis+php實(shí)現(xiàn)微博(二)發(fā)布與關(guān)注功能詳解
- redis+php實(shí)現(xiàn)微博(一)注冊(cè)與登錄功能詳解
- PHP+redis實(shí)現(xiàn)微博的拉模型案例詳解
- vue+php實(shí)現(xiàn)的微博留言功能示例
- php微信分享到朋友圈、QQ、朋友、微博
- PHP調(diào)用微博接口實(shí)現(xiàn)微博登錄的方法示例
- php新浪微博登錄接口用法實(shí)例
- 基于PHP實(shí)現(xiàn)發(fā)微博動(dòng)態(tài)代碼實(shí)例
相關(guān)文章
asp和php下textarea提交大量數(shù)據(jù)發(fā)生丟失的解決方法
2008-01-01
PHP實(shí)現(xiàn)根據(jù)時(shí)間戳獲取周幾的方法
這篇文章主要介紹了PHP實(shí)現(xiàn)根據(jù)時(shí)間戳獲取周幾的方法,涉及PHP針對(duì)時(shí)間與日期操作的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-02-02
php解決crontab定時(shí)任務(wù)不能寫入文件問題的方法分析
這篇文章主要介紹了php解決crontab定時(shí)任務(wù)不能寫入文件問題的方法,結(jié)合實(shí)例形式分析了crontab定時(shí)任務(wù)無(wú)法正常執(zhí)行的原因與解決方法,需要的朋友可以參考下2019-09-09
PHP類和對(duì)象相關(guān)系統(tǒng)函數(shù)與運(yùn)算符小結(jié)
這篇文章主要介紹了PHP類和對(duì)象相關(guān)系統(tǒng)函數(shù)與運(yùn)算符,結(jié)合實(shí)例形式總結(jié)分析了php類與對(duì)象操作過程中常用的系統(tǒng)函數(shù)與運(yùn)算符,需要的朋友可以參考下2016-09-09
php tp驗(yàn)證表單與自動(dòng)填充函數(shù)代碼
php tp驗(yàn)證表單與自動(dòng)填充函數(shù)代碼,需要的朋友可以參考下2012-02-02

