会会大厂面试官五----Redis【内存调整、OOM、淘汰策略、LRU算法】

简介: 会会大厂面试官五----Redis【内存调整、OOM、淘汰策略、LRU算法】

一、Redis面试复盘


1.1 生产上你们的redis内存设置多大?

1.2 如何配置redis并修改内存的大小?

1.3 如果内存你满了你怎么办?

1.4 redis清内存的方式?

1.5 定期删除、惰性删除了解吗?

1.6 redis缓存淘汰策略?

1.7 redis的LRU了解过吗?会不会手写LRU?


二、Redis内存设置


2.1 查看内存


如果不设置最大内存大小,或者设置最大内存大小为0,在64位操作系统下不限制内存的大小,在32位操作系统下最多使用3GB大小的内存。一般推荐为最大物理内存的3/4

# 1.查看内存大小
127.0.0.1:6379> vi redis.conf
一般为没有配置,为机器的最大内存。
打开设置maxmemory参数,为字节类型bytes,请注意转换。
一般推荐为最大物理内存的3/4。
# 2.设置内存大小100M
maxmemory 104857600
# 3.命令行配置 查询
127.0.0.1:6379> config get maxmemory   
127.0.0.1:6379> config set maxmemory  104857600
# 4.查看内存信息
127.0.0.1:6379> info memory


2.2 内存打满了出现OOM怎么办?


故意修改配置,把最大只设置为1字节。

# 1.故意修改配置,把最大只设置为1字节。  
127.0.0.1:6379> config set maxmemory 1
# 2.存储
127.0.0.1:6379> set k1 v1
# 答案:出现以下OOM
(error)OOM command not allowed when use memory > 'maxmemory'


2.3 redis内存淘汰策略?

20210204155734724.png



默认为不释放内存直到内存满,直到爆出OOM错误。


2.3.1 如果一个键过期了,会不会马上从内存中删除?


不是的

定时删除:立即删除是对CPU不友好的,因为删除操作会占用CPU的时间,如果刚刚碰上了CPU很忙的时候,比如正在排序或者计算的时候,就会给CPu造成压力。

Redis不可能时时刻刻检测所有的key的过期时间。

惰性删除:数据到达了过期时间,不做处理,等到下次访问数据时候,如果发现未过期则返回数据,如果发现过期了,则进行删除。缺点是堆内存不友好的,大量的无用数据占用空间。

定期删除:每个一段时间执行一次删除操作,并通过限制删除操作执行的时长和频率来减少操作对CPU使劲的影响。 周期性的轮询redis的时效性数据,采取随机抽取的策略,利用过期数据占比的方式控制删除频率。


2.3.2 redis6.0.8内存淘汰策略【兜底方案】


20210204161958792.png

2021020416222582.png




三、LRU 算法【哈希链表】


3.1 简介


redis的缓存淘汰策略已经提及过了

Least Recently Used 最近最少使用,是一种常见的页面置换算法。

选择最近最久未被使用的数据进行淘汰。


3.2 Leetcode算法题


运用你所掌握的数据结构,设计和实现一个LRU缓存机制,他应该支持:

获取数据get 如果关键字存在于缓存中,则获取,否则返回-1

写入数据put 如果关键字已经存在,变更数据,如果不存在,则插入。在缓存容量达到>上限时候,删除最近最久未被使用的数据进行删除后在进行插入。


想一想,查找快,插入块,删除快,而且还需要后排序-------?神魔数据结构满足?

你是否可以在O(1)时间复杂度内完成?

LRU【哈希+链表】本质就是HashMap+DoubleLinkedList


3.2.1 参考LinkedHahMap

public class LRUCacheDemo<K,V> extends LinkedHashMap<K,V> {
    // 缓存大小
    private int capacity;
    // 构造方法
    public LRUCacheDemo(int capacity) {
        super(capacity,0.75F,true);
        this.capacity = capacity;
    }
    //
    @Override
    protected boolean removeEldestEntry(Map.Entry<K, V> eldest) {
        return super.size() > capacity;
    }
    public static void main(String[] args) {
        LRUCacheDemo lruCacheDemo = new LRUCacheDemo(3);
        lruCacheDemo.put(1,"a");
        lruCacheDemo.put(2,"b");
        lruCacheDemo.put(3,"c");
        System.out.println(lruCacheDemo.keySet());
        lruCacheDemo.put(4,"d");
        System.out.println(lruCacheDemo.keySet());
        lruCacheDemo.put(3,"d");
        System.out.println(lruCacheDemo.keySet());
        lruCacheDemo.put(3,"d");
        System.out.println(lruCacheDemo.keySet());
        lruCacheDemo.put(3,"d");
        System.out.println(lruCacheDemo.keySet());
        lruCacheDemo.put(5,"d");
        System.out.println(lruCacheDemo.keySet());
    }
}

运行结果为:

[1, 2, 3]
[2, 3, 4]
[2, 4, 3]
[2, 4, 3]
[2, 4, 3]
[4, 3, 5]


3.3 哈希+链表

20210205134914984.png


目录
相关文章
|
10月前
|
人工智能 算法 NoSQL
LRU算法的Java实现
LRU(Least Recently Used)算法用于淘汰最近最少使用的数据,常应用于内存管理策略中。在Redis中,通过`maxmemory-policy`配置实现不同淘汰策略,如`allkeys-lru`和`volatile-lru`等,采用采样方式近似LRU以优化性能。Java中可通过`LinkedHashMap`轻松实现LRUCache,利用其`accessOrder`特性和`removeEldestEntry`方法完成缓存淘汰逻辑,代码简洁高效。
455 0
|
6月前
|
存储 缓存 NoSQL
工作 10 年!Redis 内存淘汰策略 LRU 和传统 LRU 差异,还傻傻分不清
小富带你深入解析Redis内存淘汰机制:LRU与LFU算法原理、实现方式及核心区别。揭秘Redis为何采用“近似LRU”,LFU如何解决频率老化问题,并结合实际场景教你如何选择合适策略,提升缓存命中率。
802 3
|
负载均衡 NoSQL 算法
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
这篇文章是关于Java面试中Redis相关问题的笔记,包括Redis事务实现、集群方案、主从复制原理、CAP和BASE理论以及负载均衡算法和类型。
一天五道Java面试题----第十天(简述Redis事务实现--------->负载均衡算法、类型)
|
9月前
|
缓存 人工智能 算法
lru算法设计与实现
本文详细介绍了LRU(Least Recently Used,最近最少使用)缓存淘汰策略的原理与实现。LRU的核心思想是:越近被访问的数据,未来被再次访问的可能性越大。文章通过Java语言实现了一个支持O(1)时间复杂度操作的LRU缓存
391 0
|
缓存 分布式计算 NoSQL
大数据-47 Redis 缓存过期 淘汰删除策略 LRU LFU 基础概念
大数据-47 Redis 缓存过期 淘汰删除策略 LRU LFU 基础概念
308 2
|
缓存 算法 前端开发
深入理解缓存淘汰策略:LRU和LFU算法的解析与应用
【8月更文挑战第25天】在计算机科学领域,高效管理资源对于提升系统性能至关重要。内存缓存作为一种加速数据读取的有效方法,其管理策略直接影响整体性能。本文重点介绍两种常用的缓存淘汰算法:LRU(最近最少使用)和LFU(最不经常使用)。LRU算法依据数据最近是否被访问来进行淘汰决策;而LFU算法则根据数据的访问频率做出判断。这两种算法各有特点,适用于不同的应用场景。通过深入分析这两种算法的原理、实现方式及适用场景,本文旨在帮助开发者更好地理解缓存管理机制,从而在实际应用中作出更合理的选择,有效提升系统性能和用户体验。
1024 1
|
缓存 NoSQL Redis
Redis性能优化问题之当Redis内存达到maxmemory后,淘汰数据的逻辑是怎样的
Redis性能优化问题之当Redis内存达到maxmemory后,淘汰数据的逻辑是怎样的
|
缓存 算法 前端开发
前端 JS 经典:LRU 缓存算法
前端 JS 经典:LRU 缓存算法
330 0
|
8月前
|
存储
阿里云轻量应用服务器收费标准价格表:200Mbps带宽、CPU内存及存储配置详解
阿里云香港轻量应用服务器,200Mbps带宽,免备案,支持多IP及国际线路,月租25元起,年付享8.5折优惠,适用于网站、应用等多种场景。
2733 0
|
8月前
|
存储 缓存 NoSQL
内存管理基础:数据结构的存储方式
数据结构在内存中的存储方式主要包括连续存储、链式存储、索引存储和散列存储。连续存储如数组,数据元素按顺序连续存放,访问速度快但扩展性差;链式存储如链表,通过指针连接分散的节点,便于插入删除但访问效率低;索引存储通过索引表提高查找效率,常用于数据库系统;散列存储如哈希表,通过哈希函数实现快速存取,但需处理冲突。不同场景下应根据访问模式、数据规模和操作频率选择合适的存储结构,甚至结合多种方式以达到最优性能。掌握这些存储机制是构建高效程序和理解高级数据结构的基础。
873 0

热门文章

最新文章