Mysql
Redis
参考链接:1 Redis 常用操作命令,非常详细! - Java技术栈 - 博客园
dbsize
keys *
Redis String
get key ; exists key 查询是否存在
set key value(不存在则新建,存在则覆盖);setnx key value (原不存在key则设置 返1,原key存在则失败返0);setex key s value (原key存在 则新建key value 设置过期时间s 返回ok。key不存在则报错)
del key
rename key newkey
查询生命周期:(秒) ttl key,(毫秒) pttl key 。-1 永不过期 -2该key不存在
设置生命周期:(秒) expire key s。(毫秒)pexpire key ms。persist key 永不过期
Redis Hash
新增:hmset hset hsetex
删除:hdel key field , del
获取:hget key field ,hgetall key, hkeys key , hlen key, hvals key
操作:HINCRBY key field increment,HINCRBYFLOAT key field increment
Redis List
新增:rpush key v1 v2..., rpushx key v
移除:lpop ,rpop
。。。。
Redis Set
新增:sadd key v1 v2
查看:SMEMBERS key,
移除:SREM key v
Redis Sorted Set 有序集合
Redis HyperLogLog
Redis 快的原因:
-
纯内存操作
-
单线程操作,避免了频繁的上下文切换
-
采用了非阻塞 I/O 多路复用机制:只有单个线程,通过跟踪每个 I/O 流的状态,来管理多个 I/O 流
Redis 的过期策略:定期删除+惰性删除
定期删除:默认是每隔100ms就随机抽取
一些设置了过期时间的key,检查其是否过期,如果过期就删除。
惰性删除:在你获取某个key的时候,Redis会检查一下 ,这个key是否设置了过期时间并且是否过期?如果过期了此时就会删除,不会给你返回任何东西。
PS:假想定期删除漏掉了很多过期key,然后你也没及时去查,也就没走惰性删除,大量过期key堆积在内存里,导致redis内存块耗尽了,咋整?引入方案:内存淘汰机制。
内存淘汰机制
1)noeviction:
当内存不足以容纳新写入数据时,新写入操作会报错。(基本不用)
2)allkeys-lru:
当内存不足以容纳新写入数据时,在所有键空间中,移除最近最少使用的key
(这个是最常用的)
3)allkeys-random:
当内存不足以容纳新写入数据时,在所有键空间中,随机移除某个key。
(这个一般没人用吧,为啥要随机,把我重要的key干掉了咋整,肯定是把最近最少使用的干掉)
4)volatile-lru:
当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的key。
(这个一般不太合适)
5)volatile-random:
当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个key。
6)volatile-ttl:
当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的key优先移除。
Redis 和数据库双写一致性问题:
最后: 这玩意好难用,换腾讯文档了,再见。
参考: