redis實(shí)現(xiàn)共同好友的思路詳解
背景
微信朋友圈的點(diǎn)贊、評(píng)論,只能看到自己好友的信息。這就涉及到了一個(gè)共同好友的概念,通過(guò)redis的set
集合可以很輕松的實(shí)現(xiàn)此功能。
共同好友實(shí)現(xiàn)思路
每個(gè)人的好友存放在set集合中。key的名字為friend_{userId}
。如下圖:
- 用戶1的好友為2,3,4
- 用戶2的好友為1,3,4
- 用戶3的好友為1,4,5
交集
用戶1和2是好友。他們的共同好友可以通過(guò)他們的交集獲取。
redis命令示例:
127.0.0.1:6379> sadd friend_1 2 3 4
(integer) 3
127.0.0.1:6379> sadd friend_2 1 4 5
(integer) 3
127.0.0.1:6379> SINTER friend_1 friend_2
1) “4”
sadd
將一個(gè)或多個(gè)成員元素加入到集合中,已經(jīng)存在于集合的成員元素將被忽略。命令詳解
SINTER
返回給定所有給定集合的交集。命令詳解
并集
獲得所有的好友信息。
127.0.0.1:6379> SUNION friend_1 friend_2
1) “1”
2) “2”
3) “3”
4) “4”
5) “5”
SUNION
返回給定集合的并集。命令詳解
差集
可以用戶好友推薦。差集出來(lái)的用戶推薦給用戶2。
127.0.0.1:6379> sadd friend_1 2 3 4
(integer) 3
127.0.0.1:6379> sadd friend_2 1 4 5
(integer) 3
127.0.0.1:6379> SDIFF friend_1 friend_2
1) “2”
2) “3”
SDIFF
返回第一個(gè)集合與其他集合之間的差異。命令詳解
更多set命令說(shuō)明:
序號(hào) | 命令及描述 |
---|---|
1 | SADD key member1 [member2] 向集合添加一個(gè)或多個(gè)成員 |
2 | SCARD key 獲取集合的成員數(shù) |
3 | SDIFF key1 [key2] 返回給定所有集合的差集 |
4 | SDIFFSTORE destination key1 [key2] 返回給定所有集合的差集并存儲(chǔ)在 destination 中 |
5 | SINTER key1 [key2] 返回給定所有集合的交集 |
6 | SINTERSTORE destination key1 [key2] 返回給定所有集合的交集并存儲(chǔ)在 destination 中 |
7 | SISMEMBER key member 判斷 member 元素是否是集合 key 的成員 |
8 | SMEMBERS key 返回集合中的所有成員 |
9 | SMOVE source destination member 將 member 元素從 source 集合移動(dòng)到 destination 集合 |
10 | SPOP key 移除并返回集合中的一個(gè)隨機(jī)元素 |
11 | SRANDMEMBER key [count] 返回集合中一個(gè)或多個(gè)隨機(jī)數(shù) |
12 | SREM key member1 [member2] 移除集合中一個(gè)或多個(gè)成員 |
13 | SUNION key1 [key2] 返回所有給定集合的并集 |
14 | SUNIONSTORE destination key1 [key2] 所有給定集合的并集存儲(chǔ)在 destination 集合中 |
以上就是redis實(shí)現(xiàn)共同好友功能的詳細(xì)內(nèi)容,更多關(guān)于redis實(shí)現(xiàn)共同好友的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Redis源碼解析:集群手動(dòng)故障轉(zhuǎn)移、從節(jié)點(diǎn)遷移詳解
這篇文章主要介紹了Redis源碼解析:集群手動(dòng)故障轉(zhuǎn)移、從節(jié)點(diǎn)遷移的相關(guān)內(nèi)容,涉及通過(guò)集群定時(shí)器函數(shù)clusterCron實(shí)現(xiàn)從節(jié)點(diǎn)遷移等知識(shí),具有一定參考價(jià)值,需要的朋友可以了解。2017-10-10使用Redis獲取數(shù)據(jù)轉(zhuǎn)json,解決動(dòng)態(tài)泛型傳參的問(wèn)題
這篇文章主要介紹了使用Redis獲取數(shù)據(jù)轉(zhuǎn)json,解決動(dòng)態(tài)泛型傳參的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-07-07NestJS+Redis實(shí)現(xiàn)手寫一個(gè)限流器
限流是大型系統(tǒng)必備的保護(hù)措施,本文將結(jié)合redis , lua 腳本 以及 Nestjs Guard 來(lái)實(shí)現(xiàn) 限流的效果,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-11-11Redis shake實(shí)現(xiàn)可視化監(jiān)控的示例代碼
Redis可視化監(jiān)控是通過(guò)監(jiān)控Redis服務(wù)器的各項(xiàng)指標(biāo)和狀態(tài),并將其以可視化的方式展示給用戶,本文給大家介紹了Redis shake實(shí)現(xiàn)可視化監(jiān)控,并通過(guò)代碼示例講解的非常詳細(xì),需要的朋友可以參考下2024-03-03Redis中key過(guò)期策略的實(shí)現(xiàn)
Key的過(guò)期機(jī)制是Redis保持高可用性的重要策略,過(guò)期策略分為惰性過(guò)期和定期過(guò)期,惰性過(guò)期在每次訪問(wèn)key時(shí)檢查是否過(guò)期,定期過(guò)期則由serverCron方法定時(shí)清理過(guò)期key,本文就來(lái)詳細(xì)的介紹一下,感興趣的可以了解一下2024-09-09