预备知识
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值,子进程不受影响。