微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

redis 写操作

预备知识

num=0
echo $num
((num++))
echo $num
显示1,表示num自增了

((num++)) | echo ok
echo $num
显示1,num没有自增。
原因是管道符(|)的优先级优于num++,因此先创建了子进程1用于((num++))和子进程2(echo ok),而在子进程1中num不可见,因此num没有自增。
可以通过"export num"使得num在子进程中可见,但是数据还是隔离的,即使子进程改变了num,父进程使用的还是原来的num,就是所谓的copy on write。

redis write

问题:redis怎么保证在提供缓存服务的同时,做磁盘写操作(RDB全量备份或AOF)?
回答:用linux系统的fork+cow(copy on write)技术,fork出子进程的时候,子进程可以看见父进程的所有key/value,这样子进程(写的进程)在做备份的时候,即使父进程(缓存的进程)改变了某个key值,子进程不受影响。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐