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