总目录:https://www.jianshu.com/p/e406a9bc93a9
数据库 - 子目录:https://www.jianshu.com/p/4499e57a5604
string
- 存储数据:单个的数据,最简单,最常用的的数据存储类型。
- 存储数据的格式:一个存储空间保存一个数据
-
存储数据的内容:通常是字符串,如果存储的是数字,可以作为数字来使用
存储空间
基础操作
增加/修改
set key value
查看
get key
删除
del key
-----------
增加/修改多个键值对
mset key1 value1 key2 value2 ...
查看多个
mget key1 key2 ...
获取字符串长度
strlen key
追加字符串
append key value
首先第一点,多数据操作肯定比单数据操作耗时少,但是数据多到一定程度,就会使redis阻塞,因为他是单进程操作。这时就要对数据进行切割,至于切割到什么程度,就是另外一回事了。
扩展操作1
当用户基数达到一定数量级,数据库肯定需要进行重新规划,分库分表。但是数据库的主键必须保证唯一性,这就是mysql分表操作中最蛋疼的一点,这时就可以用redis来保存规划所有的主键。
解决方案
- 设置数值增加指定返回的值
-
incr key :为指定的key的value增加1 value必须是数值字符串
示意 -
incrby key increment :为指定的key的value增加increment,value必须是数值字符串
示意 -
incrbyfloat key increment :为指定的key的value增加increment ,可以是浮点数,value必须是数值字符串
示意
- 设置数值减少指定范围的值
-
decr key :为指定的key的value减少1 value必须是数值字符串
示警
decr和decrby处理的value都必须是整数。
示意
-
decrby key increment :为指定的key的value减少increment,value必须是数值字符串
示意
string在redis内部是一个字符串,但是他遇到incr之类的数值操作变回作为一个数值进行计算。
redis的操作具有原子性,采用单线程来处理业务,所以无需担心高并发带来的影响。
redis的数值上限与java的长整型最大值一致。
- tips1
- redis控制数据库主键id,为数据库主键提供生成策略,确保主键一致性。
- 此方案适用于所有数据库,并且适用于数据库集群。
扩展操作2
有一个海选投票,只能通过微信投票,且每4小时可以投一票。
电商商店开启热门商品推荐,商品不能一直处于热门期,期限最长为三天,三天后自动取消热门。
新闻网站出现热门新闻,热门新闻最大的特征是时效性,如何自动控制热点新闻的时效性。
解决方案
- 设置数据的指定声明周期
1.setex key seconds value:为当前键值对设置seconds存活时间
设置10s存活时间
同样会以最后一个相同操作为准(相同命令会覆盖)
2.psetex key millseconds value:为当前键值对设置毫秒级别存活时间
- tips2
redis控制数据存活周期,通过是否存活来影响业务行为,适用于所有时效性控制。
扩展操作3
主页高频信息显示控制,例如大V的粉丝量,直播间人数。
解决方案
- 在redis中为大V用户设定用户信息,以用户主键+属性作为key,后台定时刷新即可。
粉丝量:user:id:id的值:粉丝人数的字段名 --> XXXX
博客数量:user:id:id的值:博客数量的字段名 --> XXXX
。。。。
-
使用json格式存储大V用户信息。
user:id:id的值 {粉丝人数:XXX,博客数量:XXX,...}
示意
注意事项
- 数据操作不成功的反馈
- (Interger)0 -> false 失败
- (Interger)1 -> true 成功
- 数据操作成功的之间的差异
- (Interger)3 -> 3次操作成功
- (Interger)1 -> 1次操作成功
- 数据没有查到
- (nil) -> null
- 最大存储量
- 512MB
- 数值计算最大范围
- 9223372036854775807 (2的63次方-1)