1、概述
Redis的持久化机制有两种:RDB 和 AOF ,这两种机制有什么区别?正式环境应该采用哪种机制?
我们的服务器内存资源是有限的,如果内存被Redis的缓存占满了怎么办?这就要看Redis的内存管理策略是怎么配置的了。
今天我们就来聊一下上面提出的这两个问题。
2、Redis的持久化机制
2.1 RDB
1、什么是RDB?
RDB 全称 Redis DataBase,是 Redis 默认的持久化机制。
RDB机制的原理是:每隔一段时间把Redis在内存中的数据写到磁盘,手动停止Redis服务时,也会往磁盘上写,当Redis再次启动时,会从磁盘上读取到数据,恢复到内存中。
2、RDB的好处
3、RDB的坏处
4、RDB在配置文件中的相关配置
1)文件名及文件保存路径的配置
2)设置同步硬盘的时间
save "" 代表不同步到磁盘,数据只在内存存储
save 300 100 代表有100个键发生变更,每300秒同步磁盘
3)其他配置
stop-writes-on-bgsave-error yes // 设置为yes,则在写入磁盘的的过程中出错,会停止写操作
rdbcompression yes // 设置为yes,则rdb文件在写的过程中会进行压缩,对CPU有一定损耗
rdbchecksum yes // 设置为yes,会对rdb进行校验,对性能有一定损耗
2.2 AOF
1、什么是AOF
AOF 全称 Append Only File,默认是关闭的。
AOF是以日志的形式记录Redis的写操作,读操作不会记录。以追加的方式存储文件,恢复时会将日志文件中的写操作重新执行一遍。
2、AOF的好处
3、AOF的坏处
4、AOF在配置文件中的相关配置
1)开启AOF,设置文件名
2)设置同步策略
# appendfsync always // 有一条写操作就同步一次(性能差)
appendfsync everysec // 每秒同步一次(推荐)
# appendfsync no // 不同步
3)重写策略
auto-aof-rewrite-percentage 100 // AOF文件是上次大小的100%(建议调小)
auto-aof-rewrite-min-size 64mb // AOF文件大小达到64MB(建议调大)
以上两个配置建议修改,根据实际情况调整。
2.3 RDB 、AOF 如何选择
如果只是把Redis当缓存来用,不介意数据的丢失,建议使用RDB方式,如果对数据的完整性比较在意,建议使用AOF方式。
3、Redis的内存管理机制
我们的服务器内存资源是有限的,如果内存被Redis的缓存占满了,我们应该如何处理呢?
通过调整配置文件中的 maxmemory 和 maxmemory-policy
maxmemory 是指定内存达到多大时,执行内存优化,默认单位是byte
maxmemory-policy 是执行的优化策略:
4、综述
今天聊了一下Redis的持久化机制和内存管理机制,希望能对大家有所帮助。
希望大家多多评论交流,共同成长。
关注追风人聊Java,每天更新Java干货。