对自己知识储备的感觉就是过于肤浅,很多东西知其名后就不了了之

此系列博客将记录进程分析的学习过程,希望能够多些深度

提到进程,最容易的想到就是fork系统调用,比较好和快速的找到的fork的相关信息就是 linux manual 了

fork(2)

fork - 创建一个新的进程

#include <unistd.h>

pid_t fork(void);

fork()通过复制被调用进程而创建一个新的进程,新进程称为子进程,被调用的进程称为父进程。

父子进程分别在不同的地址空间运行,在调用 fork()时两个内存空间具有相同的上下文 [1]。在内存写入时,文件映射内存mmap(2) 和文件取消映射内存munmap(2)在一个进程内执行不会影响到其他进程。

子进程对父进程完全复制除了以下几点:

  • 子进程有唯一的进程ID,并且进程ID不等于任何已经存在的进程组getpgid(2)或者会话 [2]
  • 子进程的父进程IDgeppid(2)与父进程ID相同 [3]
  • 子进程不继承父进程的内存锁mlock(2), mlockall(2) [4]
  • 子进程资源占用getrusage(2)和 CPU时间计数器times(2)被重置为0 [5]
  • 子进程的悬挂信号集(set of pending signals)初始化为空sigpending(2) [6]
  • 子进程不从父进程继承信号量调整 semop(2) [7]
  • 子进程不从父进程继承相关的记录锁 fcntl(2),但是从父进程继承 fcntl(2)打开的文件描述符锁 [8]
  • 子进程不继承父进程的定时器 setitimer(2), alarm(2), timer_create(2) [9]
  • 子进程不从父进程继承未完成的异步I/O操作aio_read(3) aio_write(3),也不从父进程继承任何的异步I/O的上下文 io_setup(2) [10]

以上的进程属性都在POSIX.1-2001中指定。父进程和子进程在以下特定于Linux的进程属性方面也有所不同:

  • 子进程不继承父进程目录的变更通知,见fcntl(2)中的F_NOTIFY [11]
  • prctl(2)PR_SET_PDEATHSIG为重置标志,因而子进程不能接收到父进程终止的信号 [12]
  • 默认的计时器从值(slack value)设置为父进程的当前计时器从值,见prctl(2)PR_SET_TIMERSLACK标志 [13]
  • 已使用madvise(2)MADV_DONTFORK标志标记的内存映射不会通过fork()继承 [14]
  • 子进程的终止信号总是SIGCHLD,见 clone(2) [15]
  • 子进程不从父进程继承由ioperm(2)设置的端口访问权限位,子进程必须通过使用ioperm(2)打开任何权限位 [16]

以下几个特点也需留意:

  • 子进程是以单线程的方式创建的。父进程整个虚拟地址空间都被复制到了子进程,包括互斥锁、条件变量和其他pthread对象的状态;由此出现的问题时使用pthread_atfork(3)可能会有帮助。
  • 在多线程程序中使用fork()后,子进程可以安全的只调用异步信号安全函数(async-signal-safe,见signal-safety(7))直到它调用 execve(2)的时候。
  • 子进程继承父进程打开文件描述符的副本。子进程中的每个文件描述符引用相同打开的文件描述符作为父进程中对应的文件描述符。两个文件描述符共享打开文件的状态标志,文件偏移量和信号驱动I/O属性(见 fcntl(2)中的F_SETOWN F_SETSIG标志)。
  • 子进程继承父进程中打开消息队列描述符的副本(见mq_overview(7))。子进程中每个文件描述符引用相同已打开的消息队列描述符作为父进程中的对应的文件描述符,意味着两个文件描述符共享相同的标志(mq_flags)。
  • 子进程继承父进程打开目录流副本(见opendir(3))。POSIX.1-2001表示父和子进程中对应的目录流可以共享目录流定位,Linux/glibc未实现。

[no] 表示待解决的问题

fork 系统调用的更多相关文章

  1. fork系统调用(转载)

    (1) fork系统调用说明 fork系统调用用于从已存在进程中创建一个新进程,新进程称为子进程,而原进程称为父进程.fork调用一次,返回两次,这两个返回分别带回它们各自的返回值,其中在父进程中的返 ...

  2. 一个fork()系统调用的问题

    转载:http://coolshell.cn/articles/7965.html 题目:请问下面的程序一共输出多少个“-”? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...

  3. 《Linux内核分析》 week6作业-Linux内核fork()系统调用的创建过程

    一.进程控制块PCB-stack_struct 进程在操作系统中都有一个结构,用于表示这个进程.这就是进程控制块(PCB),在Linux中具体实现是task_struct数据结构,它主要记录了以下信息 ...

  4. 以python代码解释fork系统调用

    import os print('Process (%s) start...' % os.getpid()) # Only works on Unix/Linux/Mac: pid = os.fork ...

  5. fork系统调用方式成为负担,需要淘汰

    微软研究人员发表论文称用于创建进程的 fork 系统调用方式已经很落后,并且对操作系统的研究与发展产生了极大的负面影响,需要淘汰,作者同时提出了替代方案.相信每位开发者都对操作系统中的 fork () ...

  6. fork()系统调用的理解

    系统调用fork()用于创建一个新进程.我们可以通过下面的代码来理解,最好是能自己敲一遍运行验证. ​#include<stdio.h> #include<stdlib.h> ...

  7. 用 set follow-fork-mode child即可。这是一个 gdb 命令,其目的是告诉 gdb 在目标应用调用fork之后接着调试子进程而不是父进程,因为在 Linux 中fork系统调用成功会返回两次,一次在父进程,一次在子进程

    GDB的那些奇淫技巧 evilpan 收录于 Security  2020-09-13  约 5433 字   预计阅读 11 分钟  709 次阅读  gdb也用了好几年了,虽然称不上骨灰级玩家,但 ...

  8. glibc中fork系统调用传参

    因为想跟踪下在新建进程时,如何处理新建进程的vruntime,所以跟踪了下fork. 以glic-2.17中ARM为例(unicore架构的没找到),实际上通过寄存器向系统调用传递的参数为: r7: ...

  9. fork系统调用关于如何让子进程先运行{wait(),waitpid(),sleep()}

    在父进程里面调用wait()和waitpid()可以确保子进程先运行,因为当子进程运行完后会变成僵尸进程,此时会发送一个信号给父进程,父进程接受到信号才会运行. 有人或许会问如果在父进程调用wait之 ...

随机推荐

  1. Cordova 开发 App

    Cordova 是一个开源的移动开发框架.允许你用标准的 Web 技术——HTML5,CSS3 和 JavaScript 做跨平台开发.应用在每个平台的具体执行被封装了起来,并依靠符合标准的 API ...

  2. [2017SEERC]Divide and Conquer

    https://www.zybuluo.com/ysner/note/1308834 题面 一个有\(n\)个点的图,上面有有两棵不同的生成树.问至少切断几条边,可以使原图不联通.并输出方案数. \( ...

  3. Java多线程系列四——控制线程执行顺序

    假设有线程1/线程2/线程3,线程3必须在线程1/线程2执行完成之后开始执行,有两种方式可实现 Thread类的join方法:使宿主线程阻塞指定时间或者直到寄生线程执行完毕 CountDownLatc ...

  4. P2746 [USACO5.3]校园网Network of Schools(Tarjan)

    P2746 [USACO5.3]校园网Network of Schools 题目描述 一些学校连入一个电脑网络.那些学校已订立了协议:每个学校都会给其它的一些学校分发软件(称作“接受学校”).注意即使 ...

  5. VBNET AutoCAD Activex 切换图层为当前图层失效

    最近有朋友询问切换图层的代码 com切换图层 <CommandMethod("mycl")> Public Sub MySubLayerChange() Dim Thi ...

  6. HTML文档中class的命名规则以及命名规范

    1.采用英文字母.数字以及“-”和“_”命名. 2.以小写字母开头,不能以数字和“-”.“_”开头. 3.命名形式:单字,连字符,下划线和驼峰. 4.使用有意义命名. 其中(3).(4)条规定主要是便 ...

  7. akka监控框架设计

    本博客介绍一种AOP.无侵入的akka监控方案,方便大家在生产使用akka的过程中对akka进行监控. 对于自身javaer来说,AOP三个字母基本就解释清楚了akka监控框架的原理.哈哈哈,不过我这 ...

  8. Rabbitmq笔记一

    几个基本概念 Producer 生产者,发送消息的一方,图中左侧的client. Consumer 消费者,接收消息的一方,图中后侧的client. Broker 消息中间件的服务节点,一般一个Rab ...

  9. codechef: BINARY, Binary Movements

    非常有毛病的一道题,我一个一个读字符死活过不去,改成整行整行读就 A 了... 做法就是...最小点覆盖... 我们发现可以把一个点向上跳看做被吃掉了,然后最顶层的点是无法向上跳所以不能被吃掉,然后被 ...

  10. magento Grid 显示下拉菜单属性

    在使用grid时自己新建了几个属性,然后其中有一个是下拉单,即deal_status protected function _prepareCollection() { $collection = M ...