首页 > 其他分享 >fork写时复制技术

fork写时复制技术

时间:2023-03-11 11:14:58浏览次数:27  
标签:fork 复制技术 复制 内存 进程 写时

学习自:https://zhuanlan.zhihu.com/p/366707663 及其评论区。

以下是我的总结:

写时复制技术详解

先说理论:

在 Linux 系统中,调用 fork 系统调用创建子进程时,并不会把父进程所有占用的内存页复制一份,而是与父进程共用相同的内存页,而当子进程或者父进程对内存页进行修改时才会进行复制 —— 这就是著名的 写时复制 机制。

 

fork中用到了写时复制技术,一个进程A进行frok了进程B,此时并不会把父进程所有占用的内存页复制一份,而是与父进程共用相同的内存页, 此后内存改为只读。当子进程或者父进程对内存数据进行修改时,会进入缺页异常。便会触发写时复制机制:将原来的内存页复制一份新的,设置复制出来的内存页要修改的进程映射,并设置该进程对该内存可读写。当最后一个进程也要修改时,也会进入异常,然后如果发现只有自己使用这片内存的话,就不需要复制内存,只是把内存设置为可读写就行了。

下图中,父进程对内存页G是只读的,当父进程对内存G进行修改操作时,发现只有自己使用这片内存的话,就可以直接改成可读写了。

 

                 

标签:fork,复制技术,复制,内存,进程,写时
From: https://www.cnblogs.com/zhuangjie/p/17205472.html

相关文章

  • 为何fork时父子进程中的变量地址相同?
    为何fork时父子进程中的变量地址相同?#include<stdio.h>#include<sys/types.h>#include<unistd.h>intmain(){//当pid>0时,说明这是在父进程中,并且此时......
  • 为何fork时父子进程中的变量地址相同?
    为何fork时父子进程中的变量地址相同?#include<stdio.h>#include<sys/types.h>#include<unistd.h>intmain(){//当pid>0时,说明这是在父进程中,并且此时......
  • linux中fork()
    原文链接:linux中fork()函数详解一、fork入门知识(一)pid_tpid_t类似一个类型,就像int型一样,int型定义的变量都是整型的,pid_t定义的类型都是进程号类型。pid_t是一个typedef......
  • 05-Redis系列之-主从复制配置和优化,fork和aof两大阻塞
    主从复制原理一台主服务器配多台从服务器,主服务器宕机后,从服务器挑选一台顶上去。从服务器同步主服务器的数据,这个同步是单向的,并且从服务器不能设置值,否则会造成数据的......
  • 在Github的fork项目中切换分支来提交PR
    在Github的fork项目中切换分支来提交PR查看远程所有分支gitbranch不带参数,列出本地已经存在的分支,并且在当前分支的前面用*标记,加上-a参数可以查看所有分支列表,包括本......
  • ForkJoinPool实践
    最近在看一本15年出版的《Java并发编程的艺术》一书,其中看到并发编程时间部分的ForkJoinPool功能时,突然发现这个功能实际使用上就是把一个大任务分成多个小的子任务,然后使用......
  • 对fork函数的进一步分析
       在fork之前的printf和write函数只会父进程调用一次,子进程不会调用,因为那时子进程还没有创建出来。当fork时,子进程被创建,程序只会往下顺序执行,但是前面父进程分配......
  • fork后内存空间的布局
     1.主进程在fork出一个子进程后,会将自己4G的空间复制一份给子进程(包括代码段、数据段、堆、栈),代码段共享同一物理内存,因为子进程中的代码和父进程中的代码是一样的,只是......
  • linux源码解析10–缺页异常之写时复制
    接上篇https://www.daodaodao123.com/?p=776本篇解析缺页异常分支之一,写时复制缺页异常;1.写时复制缺页异常触发条件(1)pte页表项的PRESENT置位(2)pte表项为不为空(3)v......
  • runtime/cgo: pthread_create failed: Resource temporarily unavailable or fork:
    出现runtime/cgo:pthread_createfailed:Resourcetemporarilyunavailable错误​情况描述:dockerps查看运行的容器,发现提示一大堆的英文代码,其中提示一句​runtime/cgo......