redis缓存机制 redis缓存技术博客

本文目录一览:

  • 1、redis缓存原理
  • 2、redis做mysql的缓存
  • 3、高性能高并发网站架构,教你搭建Redis5缓存集群
redis缓存原理Redis是一种内存高速cache,如果使用redis缓存,那经常被访问的内容会被缓存在内存中,需要使用的时候直接从内存调取 , 不知道比硬盘调取快了多少倍 , 并且支持复杂的数据结构,应用于许多高并发的场景中 。
AOF 是以appendonly方式进行数据的储存的,开启AOF模式后,所有存进redis内存的数据都会进入os cache中,然后默认1秒执行一次fsync写入追加到appendonly.aof文件中 。
redis缓存其实就是把经常访问的数据放到redis里面,用户查询的时候先去redis查询 , 没有查到就执行sql语句查询,同时把数据同步到redis里面 。redis只做读操作 , 在内存中查询速度快 。
先读取nosql缓存层,没有数据再读取mysql层,并写入数据到nosql 。nosql层做好多节点分布式(一致性hash),以及节点失效后替代方案(多层hash寻找相邻替代节点),和数据震荡恢复了 。
内存淘汰管理机制Memory Management 当内存占满之后,redis提供缓存淘汰机制 。
缓存穿透的原理缓存的正常使用如图:如图所示,缓存的使用流程:先从缓存中取数据,如果能取到,则直接返回数据给用户 。这样不用访问数据库,减轻数据库的压力 。如果缓存中没有数据,就会访问数据库 。
redis做mysql的缓存redis是一种内存性的数据存储服务,所以它的速度要比mysql快 。2,redis只支持String,hashmap,set , sortedset等基本数据类型,但是不支持联合查询,所以它适合做缓存 。
提高数据库的并发处理能力;避免写请求锁表阻塞读请求;避免单点,提高数据库的可用性;而使用Redis作为DB前面的缓存,是为了减少对MySQL的压力,提高系统的处理效率 。二者解决的问题域不同,不存在谁替代谁 。
前者终究是个缓存,不可能永久保存数据(LRU机制),支持分布式 , 后者除了缓存的同时也支持把数据持久化到磁盘等,redis要自己去实现分布式缓存(貌似最新版本的已集成),自己去实现一致性hash 。
高性能高并发网站架构,教你搭建Redis5缓存集群redis-cluster投票:容错,投票过程是集群中所有master参与,如果半数以上master节点与master节点通信超过(cluster-node-timeout) , 认为当前master节点挂掉 。
Redis集群把所有的数据映射到16384个槽中 。每个key会映射为一个固定的槽,只有当节点分配了槽,才能响应和这些槽关联的键命令 。通过cluster addslots命令为节点分配槽 。
【redis缓存机制 redis缓存技术博客】redis高可用:如果你做主从架构部署 , 其实就是加上哨兵就可以了,就可以实现,任何一个实例宕机,自动会进行主备切换 。

    推荐阅读