博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
一起采坑redis(1)--- Redis Save 与 BGSAVE 的区别
阅读量:6644 次
发布时间:2019-06-25

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

 转载-

一,save保存数据到磁盘的方式:

Redis Save 命令执行一个同步保存操作,将当前 Redis 实例的所有数据快照(snapshot)以 RDB 文件的形式保存到硬盘。

语法

redis Save 命令基本语法如下:

redis 127.0.0.1:6379> SAVE

返回值

保存成功时返回 OK 。

 

二,BGSAVE保存数据到磁盘的方式:

BGSAVE 命令执行之后立即返回 OK ,然后 Redis fork 出一个新子进程,原来的 Redis 进程(父进程)继续处理客户端请求,而子进程则负责将数据保存到磁盘,然后退出。

客户端可以通过 LASTSAVE 命令查看相关信息,判断 BGSAVE 命令是否执行成功。

 

时间复杂度:

O(N), N 为要保存到数据库中的 key 的数量。

案例:

redis> BGSAVE

Background saving started

 

 

三,结论

SAVE  保存是阻塞主进程,客户端无法连接redis,等SAVE完成后,主进程才开始工作,客户端可以连接

BGSAVE  是fork一个save的子进程,在执行save过程中,不影响主进程,客户端可以正常链接redis,等子进程fork执行save完成后,通知主进程,子进程关闭。很明显BGSAVE方式比较适合线上的维护操作,两种方式的使用一定要了解清楚在谨慎选择。

 

转载于:https://www.cnblogs.com/monkeybron/p/10908861.html

你可能感兴趣的文章
TCP握手和传输的一次观察
查看>>
CentOS下使用LVM进行分区(转)
查看>>
第六章:任务执行——Java并发编程实战
查看>>
git如何打补丁?
查看>>
如何唯一确定一个 Java 类?
查看>>
kubernetes 集群安装etcd集群,带证书
查看>>
深入理解java中的底层阻塞原理及实现
查看>>
Ambari安装之部署单节点集群
查看>>
[转]ionic3项目实战教程三(创建provider、http请求、图文列表、滑动列表)
查看>>
.net core通过多路复用实现单服务百万级别RPS吞吐
查看>>
使用AShot进行网页全页截图
查看>>
EF Core 2.1 Raw SQL Queries (转自MSDN)
查看>>
XIX Open Cup named after E.V. Pankratiev. GP of Poland(AMPPZ-2018)
查看>>
高频交易系统
查看>>
face recognition[Euclidean-distance-based loss][Center Face]
查看>>
WPF的逻辑树与视觉树(1)基本概念
查看>>
IdentityServer Topics(6)- Windows身份验证
查看>>
(原創) 解决问题时,不要只从演算法的角度去思考 (日記)
查看>>
论操作系统对双核和多路CPU的支持
查看>>
使用Webbrowser的一点心得体会
查看>>