博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
redis高级进阶(2)
阅读量:6591 次
发布时间:2019-06-24

本文共 929 字,大约阅读时间需要 3 分钟。

hot3.png

本篇主要介绍如下内容

1.redis服务器数据库
2.redis对过期键的处理
3.redis持久化策略

1.redis服务器数据库

redis服务器如果不指定数据库的具体数据,默认是16个数据库。

客户端连接到redis服务器后,需要对指定的数据库才能操作。

2.Redis对过期key的处理

我们知道redis的存储是基于内存的,通常一台普通的机器内存是有限的,所以我们需要定期处理一些不常用的数据。这就需要设置一下key的过期时间。

2.1 过期策略

假设某个key过期了,则该key保存到哈希表中,那么应该如何对这些过期key进行处理呢?通常有如下三种策略:

1.定时删除,即设置一个定时器,时常去检测过期key,这样非常占用cpu。
2.惰性删除,每次从redis中取出改key的时候判断下该key是否过期,如果过期了,则删除,返回null。这种做法占用内存。
3.定期删除,即每隔一段时间去删除一下过期键,我们限制删除的执行时长与频率。这里就需要合理的设置时长。
redis采用的是惰期删除+定期删除策略,可以在redis.conf配置文件中设置。所以说redis中存在过期键到期了,但是没有被删除的情况。

2.2 内存淘汰机制

如果惰期删除+定期删除漏掉了很多过期key,则会导致大量的过期key堆积在内存中,最终导致redis服务器内存耗尽,咋办?

我们可以设置内存最大使用量,当内存使用超出时,会实施"数据淘汰策略"。redis的数据淘汰策略有很多种,自行查看文档,且设置适合自己业务的。

3.redis持久化

redis是基于内存的,如果内存坏了,则数据会全部丢失,所以我们会想办法将数据存储到硬盘中,这就是数据持久化。

redis提供了两种持久化方案
1.RDB(基于快照),即当符合一定条件时redis会自动将内存中的数据进行快照并持久到硬盘中。这是redis默认采用的持久化方案,在redis.conf配置文件中设置。
2.AOF(文件追加),即每执行一条redis更改命令,则redis会自动将该命令写入硬盘中,该种方式一般不用。

转载于:https://my.oschina.net/u/2312022/blog/3002306

你可能感兴趣的文章
Java EnumMap工作原理及实现
查看>>
阐述Spring框架中Bean的生命周期?
查看>>
虚拟内存管理
查看>>
注水、占坑、瞎掰:起底机器学习学术圈的那些“伪科学”
查看>>
大数据小视角1:从行存储到RCFile
查看>>
第18天:京东网页头部制作
查看>>
好消息:Dubbo & Spring Boot要来了
查看>>
面向对象封装的web服务器
查看>>
南开大学提出新物体分割评价指标,相比经典指标错误率降低 69.23%
查看>>
初创公司MindMaze研发情绪反应VR,让VR关怀你的喜怒哀乐
查看>>
绕开“陷阱“,阿里专家带你深入理解C++对象模型的特殊之处
查看>>
ElasticSearch
查看>>
9-51单片机ESP8266学习-AT指令(测试TCP服务器--51单片机程序配置8266,C#TCP客户端发信息给单片机控制小灯的亮灭)...
查看>>
香港设计师带来仿生机器人,其身体 70% 构造均由3D打印完成
查看>>
不规则物体形状匹配综述
查看>>
自动化设计-框架介绍 TestCase
查看>>
CJ看showgirl已经out!VR体验才是王道
查看>>
Vue+Webpack常见问题(持续更新)
查看>>
Manually Summarizing EIGRP Routes
查看>>
spring boot 1.5.4 整合webService(十五)
查看>>