文档章节

redis高级进阶(2)

求是科技
 求是科技
发布于 01/16 16:19
字数 741
阅读 12
收藏 0

本篇主要介绍如下内容
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会自动将该命令写入硬盘中,该种方式一般不用。

© 著作权归作者所有

共有 人打赏支持
求是科技
粉丝 95
博文 447
码字总数 229554
作品 0
成都
后端工程师
私信 提问
spring boot 使用redis进行发布订阅

异步消息的方式有很多,这篇博客介绍如何使用redis进行发布订阅, 完成这个示例只需要三个文件 1.redis消息监听配置 @Configurationpublicclass RedisListenerConfig { /** * redis消息监听器...

欧阳海阳
2018/07/01
0
0
高级Java架构学习资源来了——(1-5年开发 小白误入)

大型互联网公司分布式架构原理概述 http://www.365yg.com/item/6471499647222284814/ Mysql索引底层数据结构剖析 http://www.365yg.com/item/6470767465080029710/ 老司机带你用正确的姿势看...

阿阳啊啊
2017/10/08
0
0
linux从小白到linux资深专家之路

linux从小白到linux资深专家之路 为什么学Linux,理由如下: Linux是免费; Linux是开源的,你可以修改源代码; Linux是开放的,有广泛的社区; 学习Linux可以更好的掌握计算机技术; Linux是...

lxm111111
2016/07/16
0
0
Redis如何分析慢查询操作?

什么是慢查询 和mysql的慢SQL日志分析一样,redis也有类似的功能,来帮助定位一些慢查询操作。 Redis slowlog是Redis用来记录查询执行时间的日志系统。 查询执行时间指的是不包括像客户端响应...

Java高级技术
2018/09/13
0
0
2018年慕课网视频教程(vue、docker、python、Go语言、java......)

如需下述哪一个课程,加QQ: 3475362830,非免费,几大洋,非诚勿扰! Java并发编程与高并发解决方案 ZooKeeper分布式专题与Dubbo微服务入门 Java大数据实战 Stom构建实时流处理 HBase+Spring...

杰梵
2018/10/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

网站漏洞检测之WordPress 5.0.0 修复方案

2019年正月刚开始,WordPress最新版本存在远程代码注入获取SHELL漏洞,该网站漏洞影响的版本是wordpress5.0.0,漏洞的产生是因为image模块导致的,因为代码里可以进行获取目录权限,以及文件...

网站安全
39分钟前
0
0
MySql 优化 group by 语句

默认情况下,Mysql 对所有 group by 的字段进行排序,如果查询包括 group by ,用户想要避免排序结果的消耗。可以指定 order by null 禁止排序。 mysql> EXPLAIN select * from sys_log gro...

嘴角轻扬30
今天
9
0
Linux分区&格式化&文件系统&LVM&扩容

硬件 磁盘由 盘片组、主轴马达、机械臂、磁头、驱动芯片和电路、接口等构成 2. 磁盘的分割 每个盘片很多同心圆分割为磁道 Trace 一组盘片的同径磁道叫做一个柱面 Cylinder 每个磁道又被分为很...

可数局部基
今天
5
0
刷leetcode第705题- 设计哈希集合

这个我可能做的不是很符合题意,虽然AC了,但是没有去用到hash函数之类的方式。同样使用了位运算来搞定这一切,简单易懂。上代码如下: typedef char MyHashSet;/** Initialize your data ...

锟斤拷烫烫烫
今天
4
0
【spring】- springmvc 工作原理

核心:前端控制器:DispatcherServlet 功能:MVC设计模式中的Controller角色,掌控全局 类图 原理 本质是将DispatcherServlet及关联的Spring上下文环境的初始化工作织入Servlet的生命周期内,...

ZeroneLove
今天
11
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部