zoukankan      html  css  js  c++  java
  • 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值,子进程不受影响。

    --------------------------- 知道的更多,不知道的也更多 ---------------------------
  • 相关阅读:
    什么是高大上项目?
    spring事务回滚问题
    分布式ActiveMQ集群
    基于bootstarp的Dailog
    js实现的笛卡尔乘积-商品发布
    MemcachedClient 使用说明
    docker centos容器无法yum
    java Graphics2D 画图
    spring boot 访问外部http请求
    JSON 数据重复 出现$ref
  • 原文地址:https://www.cnblogs.com/mryux/p/15460267.html
Copyright © 2011-2022 走看看