来源:https://my.oschina.net/u/920698/blog/3031587
超全面!Java核心知识总结(点击查看)
超全面!Java核心知识总结(点击查看)
-
-
-
-
Redis 内置了 复制(replication),LUA脚本(Lua scripting), LRU驱动事件(LRU eviction),事务(transactions) 和不同级别的 磁盘持久化(persistence)。
-
通过 Redis 哨兵(Sentinel)和 Redis 集群(Cluster)的自动分区,提供高可用性(high availability)。
基本数据类型
1、string 的过期时间
在重新设置值之后会被清除
127.0.0.1:6379> set hello 3
OK
127.0.0.1:6379> get hello
"3"
127.0.0.1:6379> ttl hello
(integer) -1
127.0.0.1:6379> expire hello 3000
(integer) 1
127.0.0.1:6379> set hello 4
OK
127.0.0.1:6379> ttl hello
(integer) -1
2、设置 string 类型的值可以覆盖任何其他类型
127.0.0.1:6379> sadd settest 1,2
(integer) 1
127.0.0.1:6379> type settest
set
127.0.0.1:6379> set settest hello
OK
127.0.0.1:6379> type settest
string
127.0.0.1:6379> sadd settest a,b
(error) WRONGTYPE Operation against a key holding the wrong kind of value
Redis lists 基于 Linked Lists 实现。头尾操作极速,检索较慢
有序集合的排序默认按照字典序排列
-
-
-
支持按半径索引查询的地理空间(geospatial)
应用场景
string
不管是简单和复杂的数据都可以直接转为string存储。
key:active:spring2019:title value:"2019春节活动" 操作:set
商品信息,省市区信息,活动配置等一系列不常变化的冷数据缓存
非常热门数据的缓存,游戏排行,后台每秒更新一次数据
2019春节活动参加人数
key:active:spring2019:total value:3045 操作:incr
一个人一天只能进行一次签到
key:active:checkin:userId:10000:day:20190101 value:签到时间戳 操作:expire
下面的代码不严谨,nx 可以放并发
127.0.0.1:6379> set lockkey 1 nx
OK
127.0.0.1:6379> set lockkey 1 nx
(nil)
list
push,pop