redis实际应用实现合集

一、redis实现抢红包的功能(set 数据结构)

分两种情况:

情况一:

从10个观众中随机抽2名幸运观众

首先需要把10个观众的id(具体是什么id可以根据实际业务情况自己定义)放到redis 的 set 集合里

然后随机抽取2名幸运观众,具体redis命令:

java 复制代码
127.0.0.1:6379> sadd act:002 0001
(integer) 1
127.0.0.1:6379> sadd act:002 0002
(integer) 1
127.0.0.1:6379> sadd act:002 0003
(integer) 1
127.0.0.1:6379> sadd act:002 0004
(integer) 1
127.0.0.1:6379> sadd act:002 0005
(integer) 1
127.0.0.1:6379> sadd act:002 0006
(integer) 1
127.0.0.1:6379> sadd act:002 0007
(integer) 1
127.0.0.1:6379> sadd act:002 0008
(integer) 1
127.0.0.1:6379> sadd act:002 0009
(integer) 1
127.0.0.1:6379> sadd act:002 0000
(integer) 1

插入10个观众,act:002是活动的名字,后面分别是观众id

查看观众:

java 复制代码
127.0.0.1:6379> SMEMBERS act:002
 1) "0007"
 2) "0005"
 3) "0006"
 4) "0008"
 5) "0003"
 6) "0004"
 7) "0002"
 8) "0000"
 9) "0009"
10) "0001"

插入成功

随机抽取2名幸运观众:

java 复制代码
127.0.0.1:6379> SRANDMEMBER act:002 2
1) "0001"
2) "0002"

情况二:

从10名观众中抽取奖项,其中一等奖1人,二等奖2人,三等奖3人

需要用到redis的 SPOP命令

java 复制代码
127.0.0.1:6379> spop act:002 1 #抽取一等奖 1 人
1) "0001"
127.0.0.1:6379> SMEMBERS act:002
1) "0002"
2) "0005"
3) "0007"
4) "0006"
5) "0000"
6) "0009"
7) "0003"
8) "0008"
9) "0004"
127.0.0.1:6379> spop act:002 2 #抽取二等奖 2 人
1) "0006"
2) "0005"
127.0.0.1:6379> SMEMBERS act:002
1) "0002"
2) "0007"
3) "0000"
4) "0009"
5) "0003"
6) "0008"
7) "0004"
127.0.0.1:6379> spop act:002 3 #抽取三等奖 3 人
1) "0004"
2) "0000"
3) "0003"
127.0.0.1:6379> SMEMBERS act:002
1) "0002"
2) "0007"
3) "0009"
4) "0008"
相关推荐
也无晴也无风雨1 小时前
深入剖析输入URL按下回车,浏览器做了什么
前端·后端·计算机网络
Martin -Tang1 小时前
Vue 3 中,ref 和 reactive的区别
前端·javascript·vue.js
FIN技术铺2 小时前
Redis集群模式之Redis Sentinel vs. Redis Cluster
数据库·redis·sentinel
FakeOccupational3 小时前
nodejs 020: React语法规则 props和state
前端·javascript·react.js
放逐者-保持本心,方可放逐3 小时前
react 组件应用
开发语言·前端·javascript·react.js·前端框架
曹天骄4 小时前
next中服务端组件共享接口数据
前端·javascript·react.js
阮少年、4 小时前
java后台生成模拟聊天截图并返回给前端
java·开发语言·前端
郝晨妤6 小时前
鸿蒙ArkTS和TS有什么区别?
前端·javascript·typescript·鸿蒙
AvatarGiser6 小时前
《ElementPlus 与 ElementUI 差异集合》Icon 图标 More 差异说明
前端·vue.js·elementui
喝旺仔la6 小时前
vue的样式知识点
前端·javascript·vue.js