浅谈redis应用场景

除了作为缓存使用,redis还有很多作用。

实际使用情况更为复杂,需要考虑更多因素,这里只是初步了解redis的应用场景


1.秒杀商品数量计数
设置预售商品的数量,每抢一次数量减一
decr key_name
redis是单线程的,避免了异步数据不一致问题

2.抢购计时
设置一个活动key比如:
set panic_buying double11 
设置过期时间expire panic_buying 距离活动开始时间
从后台用ttl panic_buying 获取距离活动开始的时间供前端js做倒计时效果

3.积分排名前100名
使用sorted set,用户的积分作为key的score(权重),这样使用
zrevrangebyscore key_name 99 0 withscores
取出积分前100名的用户信息

4.自增生成id
假如初始商品id为10000,set product_id 10000
每添加一个商品 incr product_id
用redis来生成id是为了防止数据库分片时自增不一致的问题,而UUID冗长,且可读性差

5.类似微博的新鲜事
sorted set 用时间戳作为权重值,事件内容作为value
zrevrangebyscore key_name 9 0 withscores,取出最近时间的10件新鲜事

6.最近访问记录
lpush user:userid:rec_visited visitor_info
获取最近访问的前10个好友
lrange user:userid:rec_visited 0 9
由于无法设置list里单个元素的过期时间,所以需要定期删除list里的元素

7.消息队列

8.单点登录系统模拟session
用户登录时用UUID生成随机token存放在cookie中,而redis中key为token,
value为对应用户的信息(密码等敏感信息除外),并设置过期时间。
需要用户登录时,从cookie先找到token,再到redis中取用户信息,若这两步都成功,那么说明用户已经登录

9.存储验证码和短信验证码

生成随机的验证码或短信验证码存入redis并设置过期时间,比如为3分钟,
若用户没在3分钟内输入正确验证码,则验证码过期无效,取验证码时为null,重新发送验证码
Redis是一种高性能的内存数据库,它被广泛用于各种应用场景。以下是几个常见的Redis应用场景: 1. 缓存:由于Redis的高性能和低延迟,它通常被用作数据缓存层,将频繁访问的数据存储在内存中,从而加快数据访问速度。 2. 会话存储:在分布式系统中,可以使用Redis存储用户会话信息,包括用户登录状态、权限等。这样可以轻松实现会话共享和负载均衡。 3. 发布/订阅系统Redis支持发布/订阅模式,可以用于实时消息传递、事件通知等场景。发布者将消息发布到指定频道,订阅者可以接收到相关消息并做出相应处理。 4. 计数器和排行榜:Redis提供了原子操作的支持,可以用于实现计数器和排行榜功能。例如,可以使用Redis的INCR操作来实现网站的访问计数器,或者根据用户的积分进行排行。 5. 分布式锁:在分布式系统中,为了保证数据的一致性和并发控制,可以使用Redis的分布式锁功能。通过使用Redis的SETNX操作来获取锁,并使用EXPIRE设置锁的过期时间,可以有效地实现分布式锁。 6. 消息队列:Redis的列表结构可以用作轻量级的消息队列。生产者将消息推入列表,消费者则从列表中弹出消息进行处理。这种方式简单高效,适用于需要异步处理的场景。 这只是一部分常见的Redis应用场景,实际上,由于Redis的灵活性和高性能,它在各种场景下都有不同的应用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值