Redis

本文探讨了缓存系统的作用,重点比较了Redis和Memcached的区别,包括Redis的单核特性、丰富的数据结构支持以及原生集群模式。同时,解释了Redis采用单线程模型却能实现高并发的原因,如内存操作、非阻塞IO多路复用和C语言实现等。此外,还介绍了Redis的数据类型,过期策略以及内存淘汰机制。
摘要由CSDN通过智能技术生成
  1. 为什么要用缓存?
    主要有两个用途:高性能、高并发
  2. Redis和Memcached的区别?
    a.Redis是单核,Memcached是多核
    b.Redis支持复杂数据存储结构(Strings,Hashes,Lists,Sets,Sorted Sets),Memcached只支持一种数据存储结构string
    c.Redis原生支持集群模式,在 Redis3.x 版本中,便能支持 cluster 模式,而 Memcached 没有原生的集群模式,需要依靠客户端来实现往集群中分片写入数据。
  3. Redis线程模型?
    Redis内部是文件事件处理器,文件事件处理器是单线程的,所以也叫单线程模型。
  4. Redis单线程为什么能支持高并发?
    Redis是走内存,内存天然就支持高并发的
  5. Redis单线程模型效率为什么这么高?
    a.纯内存操作
    b.基于非阻塞IO多路复用机制
    c.C语言实现,一般来说,C语言实现的程序“距离”操作系统更近,执行速度相对会更快
    d.单线程操作(避免了多线程的频繁上下文切换问题,预防了多线程可能产生的竞争问题)
  6. Redis都有哪些数据类型?
    a.Strings:最简单的类型,就是普通的set和get,做简单的KV缓存。
    b.Hashes:是类似Map的一种结构,这个一般就是可以将结构化的数据,比如一个对象(前提是这 个对象没嵌套其他的对象)给缓存在 Redis 里,然后每次读写缓存的时候,可以就操作 hash里的某个字段。
    c.Lists:是有序列表(通过list存储一些列表型的数据结构,类似粉丝列表、文章的评论列表之类的东西等等)
    d.Sets:是无序集合,自动去除重复
    f.Sorted Sets:是有序集合(是排序的 set,去重但可以排序,写进去的时候给一个分数,自动根据分数排序。)
    e.还有其他的(Bitmaps、HyperLogLogs、Streams等等)
  7. Redis过期策略是?
    a.定期删除:是指Redis每100ms就会随机获取一些设置过期时间的key(不是循环遍历里面所有KV),检查是否过期,如果过期就删除。
    b.惰性删除:是在获取key的时候,如果此时key已经过期,就删除,不会返回任何东西。
  8. 内存淘汰机制都有哪些?
    a.noeviction:但内存不足以容纳新的写入数据时,新写入操作是错(少用)
    b.allkeys-lru:但内存不足以容纳新的写入数据时,在键空间,移除最近最少使用的key(最常用)
    c.allkeys-random:但内存不足以容纳新的写入数据时,在键空间,随机移除某个key.
    d.volatile-lru:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,移除最近最少使用的 key(一般不太合适)。
    e.volatile-random:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,随机移除某个key。
    f.volatile-ttl:当内存不足以容纳新写入数据时,在设置了过期时间的键空间中,有更早过期时间的 key 优先移除。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值