个人学习笔记3-数据库

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 的过期策略:定期删除+惰性删除

redis的过期策略 - 子不语332 - 博客园

定期删除:默认是每隔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 和数据库双写一致性问题:

最后: 这玩意好难用,换腾讯文档了,再见。


参考:

redis的过期策略 - 子不语332 - 博客园
扫盲,为什么分布式一定要有Redis?

这可能是史上最全 Redis 高可用解决方案总结

Redis与Mysql双写一致性方案解析 - 知乎

缓存与数据库一致性系列-序言 - Kido的博客 | Kido's Blog

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值