redis入门到精通系列(二):redis操作的两个实践案例

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: 欢迎关注同名公众号《Java鱼仔》,更多知识点你值得拥有在前面一篇博客中我们已经学完了redis的五种数据类型操作,回顾一下,五种操作类型分别为:字符串类型(string)、列表类型(list)、散列类型(hash)、集合类型(set)、有序集合类型(sorted_set)。学完基础语法操作后下一步就是通过几个案例来实践操作一下redis。在这里不会采用任何其他语言,单纯使用redis进行模拟操作。

欢迎关注同名公众号《Java鱼仔》,更多知识点你值得拥有


在前面一篇博客中我们已经学完了redis的五种数据类型操作,回顾一下,五种操作类型分别为:字符串类型(string)、列表类型(list)、散列类型(hash)、集合类型(set)、有序集合类型(sorted_set)。学完基础语法操作后下一步就是通过几个案例来实践操作一下redis。


在这里不会采用任何其他语言,单纯使用redis进行模拟操作。


redis的基础操作看这一篇:https://juejin.cn/post/6866789675147722765


(一)实例一:请求调用次数的限制


应用场景:我们都知道服务器的资源总是有限的,因此如果想要让一个网站崩溃的方法之一就是无限次访问调用服务器的资源。当然了,现在的网站肯定都会有应对措施,比如熔断等操作。应对这种一个人频繁访问服务器的情况,还有一种解决方法是限制单个用户在一个时间段内调用的次数。


思路:我们可以限制单个用户在一分钟内只能调用十次,

1.设计一个计数器,记录调用的次数,把用户id作为key,调用次数作为value


2.在调用前获取次数,如果为nil,则以id为key,设置调用次数为1,生命周期为60秒;反之如果存在该key,如果value小于10,则加1;value等于10,则禁止访问。


实践:假设用户的id为123


//首先获取123的值,如果为空,则设置值为1,周期为60s
get 123
setex 123 60 1
//如果值不为空且小于10,则加1
get 123
incr 123


这里判断值是否大于10由后端逻辑控制,在这里不做讲解


网络异常,图片无法展示
|


进一步优化:用这种方式限制访问次数有一点小小的缺点:每次取到值后都要先判断是否小于10。我们可以转换一下思路,string类型存在最大值9223372036854775807,我们只需要设置设置第一次访问的值为最大值-10,当超过最大值时,redis会发起异常,通过异常来限制调用次数


实践:

get 123
setex 123 60 9223372036854775797
incr 123

(二)实例二:微信消息排列顺序


应用场景:手机接受微信消息会按最后一条消息的发送时间由近到远排序,同时置顶的消息永远会排在非置顶之前。这个功能就可以通过redis来实现。


思路:用两个list数据类型存放消息通知(用户id),一个list用来存放置顶消息,另一个list用来存放非置顶消息,再用一个string类型存放置顶用户


1.当有人发来消息时,首先查看是否是置顶用户(这一步用后端逻辑实现),再分别存放到两个list中


2.我们把list看作一个栈,先进后出。当一个用户发来消息时,先删除list中该用户,再添加该用户。这一步的目的是始终保持最后发来消息的人排在最前。


实践:假设有4个人,a b c d,模拟a的微信,因为置顶和非置顶的操作一样,这里先不考虑


消息顺序为bccdb


 

网络异常,图片无法展示
|


(三)总结


这里只是对redis进行了简单的案例实践,但是逻辑可以应用到实际环境下。

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore     ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库 ECS 实例和一台目标数据库 RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
相关文章
|
1月前
|
存储 缓存 NoSQL
深入理解Django与Redis的集成实践
深入理解Django与Redis的集成实践
54 0
|
18天前
|
缓存 NoSQL Redis
Redis 缓存使用的实践
《Redis缓存最佳实践指南》涵盖缓存更新策略、缓存击穿防护、大key处理和性能优化。包括Cache Aside Pattern、Write Through、分布式锁、大key拆分和批量操作等技术,帮助你在项目中高效使用Redis缓存。
99 22
|
24天前
|
NoSQL 关系型数据库 MySQL
MySQL与Redis协同作战:百万级数据统计优化实践
【10月更文挑战第21天】 在处理大规模数据集时,传统的单体数据库解决方案往往力不从心。MySQL和Redis的组合提供了一种高效的解决方案,通过将数据库操作与高速缓存相结合,可以显著提升数据处理的性能。本文将分享一次实际的优化案例,探讨如何利用MySQL和Redis共同实现百万级数据统计的优化。
61 9
|
1月前
|
缓存 NoSQL Java
springboot的缓存和redis缓存,入门级别教程
本文介绍了Spring Boot中的缓存机制,包括使用默认的JVM缓存和集成Redis缓存,以及如何配置和使用缓存来提高应用程序性能。
96 1
springboot的缓存和redis缓存,入门级别教程
|
1月前
|
存储 消息中间件 NoSQL
Redis 入门 - C#.NET Core客户端库六种选择
Redis 入门 - C#.NET Core客户端库六种选择
59 8
|
2月前
|
NoSQL Linux Redis
linux安装单机版redis详细步骤,及python连接redis案例
这篇文章提供了在Linux系统中安装单机版Redis的详细步骤,并展示了如何配置Redis为systemctl启动,以及使用Python连接Redis进行数据操作的案例。
69 2
|
1月前
|
消息中间件 NoSQL Kafka
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
大数据-116 - Flink DataStream Sink 原理、概念、常见Sink类型 配置与使用 附带案例1:消费Kafka写到Redis
131 0
|
3月前
|
NoSQL 安全 Java
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
这篇文章深入探讨了Redis中的String数据类型,包括键操作的命令、String类型的命令使用,以及String在Redis中的内部数据结构实现。
Redis6入门到实战------ 三、常用五大数据类型(字符串 String)
|
3月前
|
NoSQL 关系型数据库 Redis
Redis6入门到实战------ 九、10. Redis_事务_锁机制_秒杀
这篇文章深入探讨了Redis事务的概念、命令使用、错误处理机制以及乐观锁和悲观锁的应用,并通过WATCH/UNWATCH命令展示了事务中的锁机制。
Redis6入门到实战------ 九、10. Redis_事务_锁机制_秒杀
|
3月前
|
NoSQL Java Redis
Redis6入门到实战------ 八、Redis与Spring Boot整合
这篇文章详细介绍了如何在Spring Boot项目中整合Redis,包括在`pom.xml`中添加依赖、配置`application.properties`文件、创建配置类以及编写测试类来验证Redis的连接和基本操作。
Redis6入门到实战------ 八、Redis与Spring Boot整合