栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

个人学习笔记3-数据库

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

个人学习笔记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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/463083.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号