redis - 新浪微博里的共同好友的查找是如何實(shí)現(xiàn)的
問題描述
今天看了一個老視頻:http://v.youku.com/v_show/id_XMzM3NjgzMjY4.html里面說到這個問題“A關(guān)注了B,B也關(guān)注A,要得到兩個人的共同好友,好友取交集。如果A是一個粉絲有3000萬的大V,而B是粉絲只有1000的屌絲,要找出他們的共同好友,應(yīng)該怎么做?”視頻看完了,我卻米有找到答案。大家?guī)兔Ψ治鱿隆?/p>
首先得是redis,第二,得合理,不能用戶查看的時候等待個四五秒。
問題解答
回答1:這個計(jì)算過程不是一次http操作就行的,而且也不是能夠立即計(jì)算出來,除非灰常NB的算法工程師和數(shù)據(jù)工程師。這些東西都是在后臺慢慢計(jì)算,不然那些數(shù)據(jù)挖掘工程師靠什么吃飯,當(dāng)有計(jì)算出結(jié)果的時候就開始向你推送,這個時候就能夠體現(xiàn)服務(wù)器端用靜態(tài)語言并且常駐內(nèi)存的好處了。
回答2:看了一下視頻,人家說的很清楚了:預(yù)先計(jì)算。(從10分30秒開始看)就是關(guān)注(插入數(shù)據(jù))的時候,就計(jì)算一下。
回答3:利用redis的sets很容易。例:user:1:fans [2,3,4] //關(guān)注用戶1的粉絲user:1:follows [2,5,7,8] //用戶1關(guān)注的
user:2:fans [1,3,4] //關(guān)注用戶2的粉絲user:2:follows [1,7,8] //用戶2關(guān)注的
用戶1登陸的時候,取一下user:1:fans與user:1:follow的交集,能得到好友關(guān)系,那取一下user:1:follows與user:2:follows的交集,是不是就能得到共同關(guān)注的用戶?剩余的交集差集相信不用我說,你應(yīng)該也會了吧
相關(guān)文章:
1. javascript - 如何讓移動端網(wǎng)頁的輸入框固定在底部?2. MySQL中無法修改字段名的疑問3. angular.js - angular內(nèi)容過長展開收起效果4. Matlab和Python編程相似嗎,有兩種都學(xué)過的人可以說說嗎5. javascript - 微信小程序封裝定位問題(封裝異步并可能多次請求)6. 大家好,請問在python腳本中怎么用virtualenv激活指定的環(huán)境?7. 請教各位大佬,瀏覽器點(diǎn) 提交實(shí)例為什么沒有反應(yīng)8. python的前景到底有大?如果不考慮數(shù)據(jù)挖掘,機(jī)器學(xué)習(xí)這塊?9. mysql - 怎么讓 SELECT 1+null 等于 110. javascript - 微信小程序限制加載個數(shù)
