如何保证redis中存放的都是热点数据
当redis使用的内存超过了设置的最大内存时,会触发redis的key淘汰机制,在redis 3.0中有6种淘汰策略:
noeviction: 不删除策略。当达到最大内存限制时, 如果需要使用更多内存,则直接返回错误信息。(redis默认淘汰策略)
allkeys-lru: 在所有key中优先删除最近最少使用(less recently used ,LRU) 的 key。
allkeys-random: 在所有key中随机删除一部分 key。
volatile-lru: 在设置了超时时间(expire )的key中优先删除最近最少使用(less recently used ,LRU) 的 key。
volatile-random: 在设置了超时时间(expire)的key中随机删除一部分 key。
volatile-ttl: 在设置了超时时间(expire )的key中优先删除剩余时间(time to live,TTL) 短的key。
场景:
数据库中有1000w的数据,而redis中只有50w数据,如何保证redis中10w数据都是热点数据?
方案:
限定 Redis 占用的内存,Redis 会根据自身数据淘汰策略,留下热数据到内存。所以,计算一下 50W 数据大约占用的内存,然后设置一下 Redis 内存限制即可,并将淘汰策略为volatile-lru或者allkeys-lru。
设置Redis最大占用内存:
打开redis配置文件,设置maxmemory参数,maxmemory是bytes字节类型
# In short... if you have slaves attached it is suggested that you set a lower
# limit for maxmemory so that there is some free RAM on the system for slave
# output buffers (but this is not needed if the policy is 'noeviction').
#
# maxmemory <bytes>
maxmemory 268435456
设置过期策略:
maxmemory-policy volatile-lru
- 点赞
- 收藏
- 分享
- 文章举报
- Mysql里有2000w数据,redis中只存20w数据,如何保证redis中的数据都是热点数据
- 如何保证Redis中的数据都是热点数据
- mySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据
- redis如何保证数据都是热点数据
- 如何保证redis中都是热点数据
- 使用redis服务存放数据,发现在内存和磁盘都有,如何定义redis中的key
- List添加Item时, 如何去判断某个字段, 并且保证字段数据不重复性
- 关于ThreadLocal如何保证数据线程安全
- List添加Item时, 如何去判断某个字段, 并且保证字段数据不重复性
- ThrealLocal如何实现存放多个数据
- 用Visual C#如何调用Excel,如何又把数据存放到Excel表格中
- List添加Item时, 如何去判断某个字段, 并且保证字段数据不重复性
- Redis如何保证接口的幂等性?
- List添加Item时, 如何去判断某个字段, 并且保证字段数据不重复性
- [C#] ServiceStack.Redis如何批量的pop数据?
- 如何发现 Redis 热点 Key ,解决方案有哪些?
- linux下,如何迁移mysql数据库存放目录。利用软连接简单快捷实现移动到home数据盘下
- 关于ETL过程如何保证数据量的准确性和数据的正确性的讨论
- spring boot / cloud (十九) 并发消费消息,如何保证入库的数据是最新的?
- Redis学习(2)-缓存击穿、穿透、雪崩、热点数据