• 面试官:Redis 内存数据满了,会宕机吗?


    背景

    Redis 数据库内存数据满了,会宕机吗?答案是:不会让它出现存满的情况,在使用Redis的时候我们要配置Redis能使用的最大的内存大小,存到一定容量的时候还有Redis的内存淘汰策略呢,还有LRU算法进行淘汰,等等。

    Redis的内存淘汰策略

    1、Redis占用内存大小

    我们知道Redis是基于内存的key-value数据库,因为系统的内存大小有限,所以我们在使用Redis的时候可以配置Redis能使用的最大的内存大小。

    通过配置文件配置

    通过在Redis安装目录下面的redis.conf配置文件中添加以下配置设置内存大小

    通过命令修改

    Redis支持运行时通过命令动态修改内存大小

    如果不设置最大内存大小或者设置最大内存大小为0,在64位操作系统下不限制内存大小,在32位操作系统下最多使用3GB内存

    Redis的内存淘汰

    既然可以设置Redis最大占用内存大小,那么配置的内存就有用完的时候。那在内存用完的时候,还继续往Redis里面添加数据不就没内存可用了吗?

    实际上Redis定义了几种策略用来处理这种情况:

    noeviction(默认策略):对于写请求不再提供服务,直接返回错误(DEL请求和部分特殊请求除外)

    allkeys-lru:从所有key中使用LRU算法进行淘汰

    volatile-lru:从设置了过期时间的key中使用LRU算法进行淘汰

    allkeys-random:从所有key中随机淘汰数据

    volatile-random:从设置了过期时间的key中随机淘汰

    volatile-ttl:在设置了过期时间的key中,根据key的过期时间进行淘汰,越早过期的越优先被淘汰

    当使用volatile-lru、volatile-random、volatile-ttl这三种策略时,如果没有key可以被淘汰,则和noeviction一样返回错误

    如何获取及设置内存淘汰策略

    获取当前内存淘汰策略:

    127.0.0.1:6379> config get maxmemory-policy

    通过配置文件设置淘汰策略(修改redis.conf文件):

    maxmemory-policy allkeys-lru

    通过命令修改淘汰策略:

    127.0.0.1:6379> config set maxmemory-policy allkeys-lru`

  • 相关阅读:
    Appium 自动测试,读书打卡
    Appium 自动测试,读书打卡(日志)
    mac下破解安装staruml软件步骤
    基于MGR方式搭建MySQL8.0一主多从集群
    vue项目npm install下载依赖时,报error code128解决方法
    解决 ASP.NET Core 部署到 IIS,更新项目时"文件夹正在使用"错误
    windows11 升级到10.0.22598.200时安装到35%提示硬件尚未准备好
    2022网易雷火游戏研发笔试ak(4月23日)
    2022腾讯2022实习生笔试ak(4月24日后台&综合)
    2022阿里笔试编程题ak口糊(4月15日)
  • 原文地址:https://www.cnblogs.com/lyl6796910/p/14445017.html
Copyright © 2020-2023  润新知