redis抽奖并发_redis基础篇

e862d353d04ddb1bebe9913eca1dd065.png

windsearcher同学

一蓑烟雨任平生。料峭春风吹酒醒,微冷,山头斜照却相迎。回首向来萧瑟处,归去,也无风雨也无晴。

1.redis是什么

reids是一个开源的缓存框架,基于K-V对的内存缓存框架,具有丰富的数据结构,支持分布式,可持久化。

2.为什么要用redis

也就是说redis 的适用场景,在什么情况下采用缓存呢?

1.存储的数据类型不适合用关系型数据库,以关注的人为例,对应的是一个用户ID列表,适用关系型数据库只能将列表拆成多行,然后再查询出来组装

2.单机情况下的MySQL已经优化到极致了,依旧无法支持日渐增加的并发量,从软件到硬件层次去优化MySQL。软件层面最常见的加索引、硬件层面的换成固态硬盘,读写速度更快。

此时才开始考虑是否引入缓存,那为什么选择redis?

  • 简单稳定,这点笔者觉得很重要,如果三天两头出问题,我想也没有哪个公司会用它

  • 速度快,官方称10W QPS

  • 支持分布式,redis3.x推出了redis cluster

  • 持久化,也就是数据会被落地到磁盘中

  • 丰富的数据结构,字符串、哈希、列表、集合、有序集合、bitmaps、geo、hyperloglog

3.redis基础

字符串

  • set key value [ex seconds] [px milliseconds] [nx|xx]设置值,可以用set key value ex seconds nx来实现分布式锁,nx表示只能为不存在的key设置值

  • get key 获取某个key的值

  • mset key1 value1 key2 value2 批量设置并且是原子的,可以用来减少网络时间消耗

  • mget key1 key2 批量获取并且是原子的,可以用来减少网络时间消耗

哈希

其实我们可以理解 hash 为 小型Redis ,Redis 在底层实现上和 Java 中的 HashMap 差不多,都是使用 数组 + 链表 的二维结构实现的。

下面我们来看一下关于 hash 的基本操作。

  • hset key field value 设置字典中某个key的值

  • hmset key field1 value1 field2 value2 ... 批量设置

  • hget k

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Redis可以通过使用事务或Lua脚本来实现高并发下的抢购/秒杀功能。 1. 使用事务:抢购/秒杀的过程可以看做是一个先检查库存是否充足,再扣减库存的过程。使用Redis的事务可以保证这个过程是原子性的,即要么全部成功,要么全部失败。 具体实现方法如下: - 使用MULTI命令开启一个事务。 - 使用WATCH命令对库存进行监视(即设置监视器)。 - 使用GET命令获取当前库存。 - 判断库存是否充足,如果充足,则使用DECRBY命令扣减库存。 - 使用EXEC命令提交事务,如果提交成功,则说明扣减成功,否则说明被其他线程抢先扣减了库存。 示例代码如下: ```python def decrease_stock(redis_conn, stock_key): with redis_conn.pipeline() as pipeline: while True: try: pipeline.watch(stock_key) stock = int(pipeline.get(stock_key)) if stock > 0: pipeline.multi() pipeline.decr(stock_key) pipeline.execute() return True else: return False except WatchError: continue ``` 2. 使用Lua脚本:Lua脚本可以在Redis端原子性地执行多个命令,可以减少网络开销和锁竞争的问题。 具体实现方法如下: - 编写一个Lua脚本,该脚本首先使用GET命令获取当前库存,如果库存充足,则使用DECRBY命令扣减库存,否则返回0。 - 在Python中使用Redis的EVAL命令执行该Lua脚本。 示例代码如下: ```python def decrease_stock(redis_conn, stock_key): script = """ local stock = tonumber(redis.call('GET', KEYS[1])) if stock > 0 then redis.call('DECRBY', KEYS[1], 1) return 1 else return 0 end """ result = redis_conn.eval(script, 1, stock_key) return bool(result) ``` 以上两种方法都可以实现高并发下的抢购/秒杀功能,但是使用Lua脚本的方法效率更高,因为在Redis端执行命令可以减少网络开销和锁竞争的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值