写时拷贝机制(copy on write)(转自搜狐达人空间的笔记)
2016-05-29 19:05
302 查看
Linux中内存的管理和分配
Linux的页目录表和页表是在程序head.s中设置的.head.s程序在物理地址0处存放了一个页目录表,紧随其后的是4个页表.
page.s程序用于实现页异常中断处理过程,其中缺页和页写保护引起的中断分别调用memory.c的do_no_page()和do_wp_page()函数进行处理.do_no_page()会把需要的页面从块设备中取到内存指定位置处.在共享内存页面的情况下,do_wp_page()会复制被写的页面,同时取消页面的共享.
写时复制机制
为了节约物理内存,在调用fork()生成新进程时,新进程与原进程会共享同一内存区.只有当其中一进程进行写操作时,系统才会为其另外分配内存页面.这就是写时复制机制(copy on write)的意思.
当进程A使用系统调用fork创建一个子进程B时,由于子进程B实际上是父进程A的一个拷贝,因此会拥有与父进程相同的物理页面.为了节约内存和加快创建速度的目标,fork()函数会让子进程B以只读方式共享父进程A的物理页面.同时将父进程A对这些物理页面的访问权限也设成只读.这样,当父进程A或子进程B任何一方对这些已共享的物理页面执行写操作时,都会产生页面出错异常(page_fault int14)中断,此时CPU会执行系统提供的异常处理函数do_wp_page()来解决这个异常.
do_wp_page()会对这块导致写入异常中断的物理页面进行取消共享操作,为写进程复制一新的物理页面,使父进程A和子进程B各自拥有一块内容相同的物理页面.最后,从异常处理函数中返回时,CPU就会重新执行刚才导致异常的写入操作指令,使进程继续执行下去.
Linux的页目录表和页表是在程序head.s中设置的.head.s程序在物理地址0处存放了一个页目录表,紧随其后的是4个页表.
page.s程序用于实现页异常中断处理过程,其中缺页和页写保护引起的中断分别调用memory.c的do_no_page()和do_wp_page()函数进行处理.do_no_page()会把需要的页面从块设备中取到内存指定位置处.在共享内存页面的情况下,do_wp_page()会复制被写的页面,同时取消页面的共享.
写时复制机制
为了节约物理内存,在调用fork()生成新进程时,新进程与原进程会共享同一内存区.只有当其中一进程进行写操作时,系统才会为其另外分配内存页面.这就是写时复制机制(copy on write)的意思.
当进程A使用系统调用fork创建一个子进程B时,由于子进程B实际上是父进程A的一个拷贝,因此会拥有与父进程相同的物理页面.为了节约内存和加快创建速度的目标,fork()函数会让子进程B以只读方式共享父进程A的物理页面.同时将父进程A对这些物理页面的访问权限也设成只读.这样,当父进程A或子进程B任何一方对这些已共享的物理页面执行写操作时,都会产生页面出错异常(page_fault int14)中断,此时CPU会执行系统提供的异常处理函数do_wp_page()来解决这个异常.
do_wp_page()会对这块导致写入异常中断的物理页面进行取消共享操作,为写进程复制一新的物理页面,使父进程A和子进程B各自拥有一块内容相同的物理页面.最后,从异常处理函数中返回时,CPU就会重新执行刚才导致异常的写入操作指令,使进程继续执行下去.
相关文章推荐
- 标准C++类string的Copy-On-Write技术
- Copy-On-Write技术
- Linux写时拷贝技术(copy-on-write)
- 标准C++类string的Copy-On-Write技术(一) 推荐
- 标准C++类string的Copy-On-Write技术(二)
- 标准C++类string的Copy-On-Write技术(三)
- Docker存储驱动之AUFS简介
- 深入探究fork函数写时拷贝技术的实现
- 借shared_ptr实现copy-on-write(2)
- 单例、ConcurrentMap、Copy-On-Write
- 详谈Linux写时拷贝技术(copy-on-write)必看篇
- 连载shell(一): 交互式脚本,随日期变化,数值运算
- Linux串口编程
- 三层架构
- Linux C 指针数组 数组指针 函数指针 的使用实例
- 【转】 Linux内核spin_lock、spin_lock_irq 和 spin_lock_irqsave 分析
- Cmake 构建程序
- codeigniter nginx rewrite规则配置【转】
- nginx基本配置与参数说明
- Linux的chattr与lsattr命令详解