Redis Save 命令执行一个同步保存操作,将当前 Redis 实例的所有数据快照(snapshot)以 RDB 文件的形式保存到硬盘, 默认路径可以登录到Redis用如下命令查询:
[superman@labs redis]$ ./bin/redis-cli -p Port
127.0.0.1:6379> auth insert-redis-password-here
OK
127.0.0.1:6379> config get dir
1) "dir"
2) "/var/lib/redis"
redis Save 命令基本语法如下:
127.0.0.1:6379> auth insert-redis-password-here
OK
127.0.0.1:6379> save
默认生成文件/var/lib/redis/dump.rdb
BGSAVE 命令执行之后立即返回 OK ,然后 Redis fork 出一个新子进程,原来的 Redis 进程(父进程)继续处理客户端请求,而子进程则负责将数据保存到磁盘,然后退出。
客户端可以通过 LASTSAVE 命令查看相关信息,判断 BGSAVE 命令是否执行成功。
案例:
redis> BGSAVE
Background saving started
结论
SAVE 直接调用rdbSave ,阻塞 Redis 主进程 ,客户端无法连接redis,等SAVE完成后,主进程才开始工作,客户端可以连接
1 个回复
空心菜 - 心向阳光,茁壮成长
说明
Redis Save 命令执行一个同步保存操作,将当前 Redis 实例的所有数据快照(snapshot)以 RDB 文件的形式保存到硬盘, 默认路径可以登录到Redis用如下命令查询:
redis Save 命令基本语法如下:
默认生成文件
/var/lib/redis/dump.rdb
BGSAVE 命令执行之后立即返回 OK ,然后 Redis fork 出一个新子进程,原来的 Redis 进程(父进程)继续处理客户端请求,而子进程则负责将数据保存到磁盘,然后退出。
客户端可以通过 LASTSAVE 命令查看相关信息,判断 BGSAVE 命令是否执行成功。
案例:
结论
SAVE 直接调用rdbSave ,阻塞 Redis 主进程 ,客户端无法连接redis,等SAVE完成后,主进程才开始工作,客户端可以连接
BGSAVE 则 fork 出一个子进程,子进程负责调用 rdbSave,在执行save过程中,不影响主进程,客户端可以正常链接redis,等子进程fork执行save完成后,通知主进程,子进程关闭。很明细BGSAVE方式比较适合线上的维护操作,两种方式的使用一定要了解清楚在谨慎选择。