Redis系列学习文章分享---第九篇(Redis快速入门之好友关注--关注和取关 -共同关注 -Feed流实现方案分析 -推送到粉丝收件箱 -滚动分页查询)

简介: Redis系列学习文章分享---第九篇(Redis快速入门之好友关注--关注和取关 -共同关注 -Feed流实现方案分析 -推送到粉丝收件箱 -滚动分页查询)

1. 好友关注-关注和取关

1.1 概述

在好友关注系统中,用户可以关注其他用户,也可以取消关注。

1.2 示例代码

Jedis jedis = new Jedis("localhost", 6379);
// 关注用户
String userId = "user123";
String friendId = "friend456";
jedis.sadd("following:" + userId, friendId);
// 取消关注用户
jedis.srem("following:" + userId, friendId);

2. 好友关注-共同关注

2.1 概述

共同关注指的是两个用户都关注了同一个用户,可以用于发现共同兴趣的朋友。

2.2 示例代码

Jedis jedis = new Jedis("localhost", 6379);
// 获取共同关注的用户
String user1Id = "user123";
String user2Id = "user456";
Set<String> commonFollowing = jedis.sinter("following:" + user1Id, "following:" + user2Id);
System.out.println("共同关注的用户: " + commonFollowing);

3. 好友关注-Feed流实现方案分析

3.1 概述

Feed流是根据用户关注的人发布的内容动态生成的流,用户可以看到自己关注的人的最新动态。

3.2 实现方案

可以使用Redis的有序集合(sorted set)来存储用户发布的内容,按照时间戳作为分数,实现按时间排序的功能。


4. 好友关注-推送到粉丝收件箱

4.1 概述

当用户发布新的内容时,需要将这些内容推送到其粉丝的收件箱中,以便粉丝能够及时看到。

4.2 示例代码

Jedis jedis = new Jedis("localhost", 6379);
// 将用户发布的内容推送到粉丝的收件箱中
String userId = "user123";
String content = "今天发现了一家很不错的餐厅!";
Map<String, String> post = new HashMap<>();
post.put("userId", userId);
post.put("content", content);
String postId = String.valueOf(System.currentTimeMillis());
jedis.hmset("post:" + postId, post);
// 获取粉丝列表
Set<String> followers = jedis.smembers("followers:" + userId);
for (String follower : followers) {
    jedis.lpush("inbox:" + follower, postId);
}

5. 好友关注-滚动分页查询收件箱的思路

5.1 概述

滚动分页查询收件箱是指用户可以一次获取一定数量的收件箱内容,并且可以不断滚动加载更多内容。

5.2 实现思路

可以使用Redis的列表(list)来存储收件箱内容,用户可以通过分页获取列表中的内容,并根据需要滚动加载更多内容。


6. 好友关注-实现滚动分页查询

6.1 概述

实现滚动分页查询,让用户能够方便地浏览自己收件箱中的内容。

6.2 示例代码

Jedis jedis = new Jedis("localhost", 6379);
// 滚动分页查询收件箱内容
String userId = "user123";
int pageNum = 1;
int pageSize = 10;
List<String> inbox = jedis.lrange("inbox:" + userId, (pageNum - 1) * pageSize, pageNum * pageSize - 1);
for (String postId : inbox) {
    Map<String, String> post = jedis.hgetAll("post:" + postId);
    System.out.println("Post ID: " + postId + ", Content: " + post.get("content"));
}

感谢您阅读本篇Redis实战篇-好友关注的技术博客!如果您有任何问题或建议,请随时在评论区留言。

相关文章
|
canal NoSQL 关系型数据库
Redis应用—7.大Value处理方案
本文介绍了一种用于监控Redis大key的方案设计及其实现步骤。主要内容包括:方案设计、安装与配置环境、binlog数据消费者。
491 29
Redis应用—7.大Value处理方案
|
6月前
|
存储 监控 NoSQL
Redis高可用架构全解析:从主从复制到集群方案
Redis高可用确保服务持续稳定,避免单点故障导致数据丢失或业务中断。通过主从复制实现数据冗余,哨兵模式支持自动故障转移,Cluster集群则提供分布式数据分片与水平扩展,三者层层递进,保障读写分离、容灾切换与大规模数据存储,构建高性能、高可靠的Redis架构体系。
|
监控 NoSQL Java
场景题:百万数据插入Redis有哪些实现方案?
场景题:百万数据插入Redis有哪些实现方案?
235 1
场景题:百万数据插入Redis有哪些实现方案?
|
7月前
|
监控 NoSQL 关系型数据库
保障Redis与MySQL数据一致性的强化方案
在设计时,需要充分考虑到业务场景和系统复杂度,避免为了追求一致性而过度牺牲系统性能。保持简洁但有效的策略往往比采取过于复杂的方案更加实际。同时,各种方案都需要在实际业务场景中经过慎重评估和充分测试才可以投入生产环境。
398 0
|
10月前
|
NoSQL 算法 安全
redis分布式锁在高并发场景下的方案设计与性能提升
本文探讨了Redis分布式锁在主从架构下失效的问题及其解决方案。首先通过CAP理论分析,Redis遵循AP原则,导致锁可能失效。针对此问题,提出两种解决方案:Zookeeper分布式锁(追求CP一致性)和Redlock算法(基于多个Redis实例提升可靠性)。文章还讨论了可能遇到的“坑”,如加从节点引发超卖问题、建议Redis节点数为奇数以及持久化策略对锁的影响。最后,从性能优化角度出发,介绍了减少锁粒度和分段锁的策略,并结合实际场景(如下单重复提交、支付与取消订单冲突)展示了分布式锁的应用方法。
816 3
|
存储 监控 NoSQL
Redis集群有哪些方案
1. 主从复制集群 : 读写分离, 一主多从 , 解决高并发读的问题 2. 哨兵集群 : 主从集群的结构之上 , 加入了哨兵用于监控集群状态 , 主节点出现故障, 执行主从切换 , 解决高可用问题 3. Cluster分片集群 : 多主多从 , 解决高并发写的问题, 以及海量数据存储问题 , 每个主节点存储一部分集群数据
|
消息中间件 缓存 NoSQL
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
缓存与数据库的一致性方案,Redis与Mysql一致性方案,大厂P8的终极方案(图解+秒懂+史上最全)
|
存储 缓存 NoSQL
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
云端问道21期方案教学-应对高并发,利用云数据库 Tair(兼容 Redis®*)缓存实现极速响应
397 1
|
存储 监控 NoSQL
Redis集群方案汇总:概念性介绍
本文介绍了Redis的三种高可用和分布式解决方案:**Redis Replication(主从复制)**、**Redis Sentinel(哨兵模式)** 和 **Redis Cluster(集群模式)**。Redis Replication实现数据备份和读写分离,适合数据安全和负载均衡场景;Redis Sentinel提供自动故障转移和监控功能,适用于读写分离架构;Redis Cluster通过分布式存储和自动故障转移,解决单点性能瓶颈,适合大规模数据和高并发场景。文中还详细描述了各方案的工作原理、优缺点及适用场景。
375 0
|
存储 NoSQL 大数据
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
大数据-51 Redis 高可用方案CAP-AP 主从复制 一主一从 全量和增量同步 哨兵模式 docker-compose测试
211 3