首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux进程创建过程分析(_do_fork do_fork详解)--Linux进程的管理调度(八)

,也叫线程,是共享资源的进程) 系统调用 描述 fork fork创造的子进程是父进程的完整副本,复制了父亲进程的资源,包括内存的内容task_struct内容 vfork vfork创建的子进程进程共享数据段...,而且由vfork()创建的子进程将先于父进程运行 clone Linux创建线程一般使用的是pthread库 实际上linux也给我们提供了创建线程的系统调用,就是clone fork, vfork...parent_tidptr和child_tidptr), 用于线程库通信 创建进程的流程 _do_fork和早期do_fork的流程 _do_fork和do_fork在进程的复制的时候并没有太大的区别..., 他们就只是在进程tls复制的过程中实现有细微差别 所有进程复制(创建)的fork机制最终都调用了kernel/fork.c中的_do_fork(一个体系结构无关的函数), _do_fork以调用...进程创建到执行过程如下图所示 ?

2.4K20
您找到你想要的搜索结果了吗?
是的
没有找到

进程和线程的创建过程

页码:第150页 2013-10-09 11:43:08 进程和线程的创建过程 在内核中,Windows 创建一个进程过程是从NtCreateProcess 函数开始的,它首先创建一个执行体进程对象...另外,建立起独立的内存地址空间是Windows 创建进程过程中不可避免的步骤,关于进程地址空间的创建,请参考4.3.1 节。...线程的系统服务表(ServiceTable 域)以及APC 和定时器相关的域也在这个函数中被初始化。此外,线程的内核栈也在这个函数中被创建并初始化。...因为线程的创建是在进程已经创建完成以后才做的动作,所以,线程创建是一个相对简单的过程。而完整的进程创建过程其实并不像前面介绍的步骤那么直截了当。...在WRK中并不能看到完整的进程创建过程,但是理解这一过程仍然是非常必要的,下面我们从上层应用程序的角度来讨论进程创建过程

1.5K20

Linux内核进程原理

Linux内核中,进程又称为任务(task),进程的虚拟地址空间可以分为用户虚拟地址空间和内核虚拟地址空间,所有进程共享内核虚拟地址空间,又各自拥有独立的用户虚拟地址空间。...而进程在被CPU调度运行,等待CPU资源分配以及等待外部事件时会属于不同的状态: 创建态:创建进程 就绪态:进程获取可以运作所有资源及准备相关条件 执行态:进程正在使用...图片 Linux内核提供了一组宏值来表示进程的状态: TASK_RUNNING(可运行状态或就绪状态);Linux并没有严格区分运行态或就绪态,统一为TASK_RUNNING...,系统中其他进程“并行执行”(实际上也并行于内核自身的执行)。....实现文件系统的事务日志 内核线程是独立运行在内核空间的进程普通用户进程区别在于内核线程没有独立的进程地址空间。

1.9K10

Linux系统编程】进程概念基本创建

课本上称之为PCB(process control block),Linux操作系统下的PCB是: task_struct 所以: 我们每运行一个程序,除了要把它对应的指令和数据加载到内存,操作系统还会为它创建一个...不是的 进程包括了程序加载到内存中的指令和数据,以及内核中之关联的进程控制块(PCB) 所以,我们这里给出一个进程的概念: 进程=程序加载到内存中的指令和数据+内核中之关联的进程控制块(PCB...3. task_struct—PCB的一种 在Linux中描述进程的结构体叫做task_struct task_struct是Linux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息.../执行这个可执行程序,操作系统就会把它加载到内存,同时为他建立PCB(在Linux上是task_struct),然后它就变成了进程 那我们如何查看这个进程呢?...所以: 一个进程创建好,操作系统会自动在proc目录下创建一个以新增进程的PID命名的文件夹 我们可以进去看看 这里面有很多内容,这些内容其实就是当前进程的相关属性信息 这些东西大多我们还看不懂

10410

Linux创建进程

Linux的下是由父进程来完成的,创建完成的新进程是子进程对于子进程它有两种执行顺序的可能性: 父进程和子进程并发执行; 子进程先执行,父进程等待子进程执行完毕。...在Linux下的fork函数用于创建一个新的进程,使用fork()的函数来创建一个进程时,子进程只是完全复制父进程的资源。这样得到的子进程和父进程是独立的,具有良好的并发性。...Linux的采用了copy-on-write技术(COW),即:只有在子进程中发生写入操作的时候,才真正的去复制父进程的资源,否则不进行复制操作,比如在fork的子进程中只是调用exec函数来执行另外一个可执行文件...总结一下:fork函数创建的子进程是父进程的复制,子进程和父进程并发执行来段代码测试一下。...除了fork之外,Linux的系统还提供了vfork的函数来建立一个新进程.vfork建立的新进程和fork的不同之处在于: vfork创建的子进程和父进程是共享地址空间的,而不是复制,因此子进程中的数据和父进程中的数据是共享的

2.1K10

Linux进程概念进程状态

文章目录 一、什么是进程 1、进程概念 2、进程描述 -- PCB 二、进程的一些基本操作 1、查看进程 2、结束进程 2、通过系统调用获取进程标示符 3、通过系统调用创建进程 三、进程状态 1...运行状态 操作系统为了合理分配CPU以及各种硬件资源,也为了更好的调度各个进程,会为CPU创建一个进程队列,为每一个硬件都创建一个等待队列;而让某一个进程处于运行状态本质上就是将该进程对应的PCB放入CPU...,所以我们需要指定优先级来合理的分配资源; Linux中优先级的特点 Linux 中优先级的表示维护通过两个变量 PRI (priority) 和 NI (nice) 来完成,每个进程默认的 PRI...都是 80,NI 都是 0;我们可以通过修改 NI 的值来调整进程的优先级,NI 的改动范围为 [-20, 19];PRI NI 的和越小,进程的优先级就越高; Linux 中我们通过 ps -l...上下文保护上下文恢复 CPU在进行进程切换时要进行上下文保护上下文恢复: 我们的进程在运行时会产生非常多的临时数据,同时CPU中存在一套寄存器硬件,当进程运行时,进程的PCB会被放入CPU内的寄存器中

5.5K00

原 浅谈Linux进程调度过程

在操作系统运行过程中,由于CPU bound和I/O bound,进行进程的调度自然是常事。...schedule()进行进程切换,也可以在中断处理过程中进行调度,也就是说内核线程作为一类的特殊的进程可以主动调度,也可以被动调度; 用户态进程无法实现主动调度,仅能通过陷入内核态后的某个时机点进行调度...,即在中断处理过程中进行调度。...SAVE_ALL //保存现场 中断处理过程中或中断返回前调用了schedule(),其中的switch_to做了关键的进程上下文切换 标号1之后开始运行用户态进程Y(这里Y曾经通过以上步骤被切换出去过因此可以从标号...陈政/arc001    原创作品转载请注明出处  《Linux内核分析》MOOC课程

1.6K80

docker容器运行原理以及创建过程

Docker容器的创建过程Docker容器的创建过程可以简单概括为以下几个步骤:选择镜像首先,需要选择一个Docker镜像,该镜像将被用作容器的基础。...Docker容器的运行原理Docker使用Linux容器技术,该技术利用Linux内核的cgroups和命名空间功能,为应用程序提供隔离的环境。...容器使用Linux的命名空间来创建一个隔离的环境。...在Docker中,容器的创建和运行是通过Docker引擎完成的。Docker引擎是一个客户端-服务器应用程序,它允许用户通过Docker APIDocker守护进程交互。...在本地文件系统中创建一个可写的容器层。这个层将包含应用程序和其依赖项。使用Linux命名空间和cgroups创建容器。

78720

Linux进程控制:理解什么是进程创建进程终止,进程等待 | 进程替换

一.进程创建 fork函数创建进程,新进程为子进程,原进程为父进程; fork函数包含在头文件 进程调用fork,当控制转移到内核中的fork代码后,内核做: 分配新的内存块和内核数据结构给子进程...三.进程等待 进程等待是什么? 通过系统调用wait/waitpid,来进行对子进程进行状态检测回收的功能! 为什么要进程等待?...wait等效。         pid>0,等待其进程IDpid相等的子进程。 status:  WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。...即父进程会检查一次看子进程有没有退出,没有则返回0,此时父进程可以做一些自己的事,而不是一味的等待子进程的退出,在子进程退出前循环以上的过程,直到子进程退出,返回 >0 的一个数,返回负数则表示等待失败...进程替换的原理进程在替换时,只会替换掉物理内存中原来程序的代码和数据,其它的并不会动,且调用exec并不创建进程,所以调用exec前后该进程的id并未改变。

16710

Linux进程控制(创建、终止、等待)

环境:centos7.6,腾讯云服务器 Linux文章都放在了专栏:【Linux】欢迎支持订阅 相关文章推荐: 【Linux】冯.诺依曼体系结构操作系统 【Linux进程理解学习Ⅰ-进程概念...【Linux进程理解学习Ⅱ-进程状态 【Linux进程理解学习Ⅲ-环境变量 【Linux进程理解学习Ⅳ-进程地址空间 浅谈Linux下的shell--BASH 【Linux进程优先级...&前后台理解 前言 在前文中我们了解了fork函数的使用,以及写时拷贝机制的原理等,并且也学习了什么是僵尸进程,但是并没有具体讲到应如何处理僵尸进程,本次章节将对fork函数以及如何终止进程,还有僵尸进程的处理做更为详细的探讨...进程创建 再谈fork函数 #include pid_t fork(void); 返回值:创建进程成功后,给子进程返回0,父进程返回子进程的pid,出错返回-1 pid_t...我们在Linux下可以通过echo $?指令查看最近的进程的退出码。 ​

3.4K40

Linux进程控制【创建、终止、等待】

---- 前言 进程 创建后,需要对其进行合理管理,光靠 OS 是无法满足我们的需求的,此时可以运用 进程 控制相关知识,对 进程 进行手动管理,如创建 进程、终止 进制、等待 进程 等,其中等待 进程...可以有效解决僵尸 进程 问题 汽车的中控台,可以对汽车进行各种操作 ---- ️正文 本文涉及的代码都是以 C语言 实现的 1、进程创建 在学习 进程控制 相关知识前,先要对回顾如何创建 进程...,退出 } 观察结果不难发现,两个子进程已经成功创建,但最晚创建进程,总是最先运行,这是因为 fork 创建进程后,先执行哪个进程取决于调度器 得到子进程后,此时可以在一个程序中同时执行两个进程...(父进程非阻塞的情况下) 注意:fork 可能创建进程失败 系统中的进程过多时 实际用户的进程数超过了限制 1.2、写时拷贝 在【进程地址空间】一文中,谈到了写时拷贝机制,实现原理就是通过 页表+MMU...---- 总结 以上就是关于 Linux进程控制(创建、终止、等待) 的相关知识了,我们学习了 子进程 是如何被创建的,创建后又是如何终止的,以及 子进程 终止 父进程 需要做些什么,有了这些知识后,

21110

Linux创建进程达到65535的方法

Linux创建进程据说消耗很少,这个一直是Linux的特点,于是就专门测试Linux创建进程的极限,测试代码如下: //fork.c #include #include <stdlib.h...65535,但是我们还不能使用blue帐户创建65535个进程,我们在Linux还需要设置内核参数kernel.pid_max,这个参数我默认安装都是32768,所以即使使用root帐户,却不设置这个内核参数.../fork 我的虚拟机Linux内存是512M,在创建6千多个进程时,程序运行得很慢,通过vmstat命令观察,发现swap内存的置入置出很频繁,可以判断是由于内存不足,使用虚拟内存,导致频繁的IO操作...测试代码中,创建的子进程,占用的内存相当小,实际使用中,只可能比测试代码创建进程使用更多的内存,所以相应的,同样配置的机器,能创建的可用进程应该是更少的。...总结 以上所述是小编给大家介绍的Linux创建进程达到65535的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对ZaLou.Cn网站的支持!

1.6K31

Linux创建进程达到65535的方法

Linux创建进程据说消耗很少,这个一直是Linux的特点,于是就专门测试Linux创建进程的极限,测试代码如下: //fork.c #include  #include <stdlib.h...,默认是创建65535个进程,如果无法创建,就打印出错误。...blue帐户创建进程数的硬限制和软限制都是65535,但是我们还不能使用blue帐户创建65535个进程,我们在Linux还需要设置内核参数kernel.pid_max,这个参数我默认安装都是32768.../fork 我的虚拟机Linux内存是512M,在创建6千多个进程时,程序运行得很慢,通过vmstat命令观察,发现swap内存的置入置出很频繁,可以判断是由于内存不足,使用虚拟内存,导致频繁的IO操作...测试代码中,创建的子进程,占用的内存相当小,实际使用中,只可能比测试代码创建进程使用更多的内存,所以相应的,同样配置的机器,能创建的可用进程应该是更少的。

1.6K20

Linux进程创建参数标志位-Cloneflags

Linux世界中,clone()系统调用通过复制调用进程创建一个新进程。新进程称为子进程,原始进程称为父进程。clone()系统调用有几个选项,允许我们控制父进程和子进程之间资源的共享。...Cloneflags是一个用于指定创建 Linux 命名空间的标志位, 是 Linux 内核中用于进程创建的参数之一,它用于控制新进程如何进程共享资源。...CLONE_SIGHAND:使新进程共享信号处理程序。 CLONE_THREAD:使新进程成为调用进程的线程,进程共享进程 ID 和资源,但拥有独立的栈。...我们可以通过一些例子来熟悉下 CLONE_VM CLONE_VM标志将使新进程共享进程相同的内存空间,这意味着它们将具有相同的虚拟地址空间。...后面我们利用这些原理来深入的理解docker 的底层实现原理编写对应功能的demo。

14410

linux内核进程创建fork源码解析

平时写过多进程多线程程序,比如使用linux的系统调用fork创建进程和glibc中的nptl包里的pthread_create创建线程,甚至在java里使用Thread类创建线程等,虽然使用问题不大...,但需要知道底层原理。...这次在自己写操作系统的时候,看了一遍linux内核的进程创建过程。算是有了比较深入的理解。     进程概念:进程是对正在运行程序的一个抽象。...pid } 其中最主要的copy过程全部交给了copy_process,此函数复制了所有进程资源信息,下面看此函数 /* * clone_flags:fork标志 * stack_start:新进程栈起始地址...group_leader是新进程本身,pgid是当前进程创建进程进程)的pgid,tgid是新进程本身,parent是当前进程创建进程进程)。

8.6K21

LinuxLinux进程控制 --- 进程创建、终止、等待、替换、shell派生子进程的理解…

---- ---- 一、进程创建 1.调用fork之后,内核都做了什么? 1....,究其原因就是因为在程序运行过程中,出现了两个进程,也就是两个执行流,才导致了分支语句的“同时执行”。...(子进程执行新程序的代码和数据) 1.创建进程的目的?...创建进程一般有两个目的: 1.让子进程执行父进程代码的一部分,也就是执行父进程对应的磁盘上的代码和数据的一部分。...下面是运行结果,子进程被替换为ls进程,ls进程正常退出退出码为0,终止信号为0. 故意使得程序替换失败,则进程退出也是按照我们设定的退出码所退出的。 3.程序替换原理 1.

14.4K30

Linux创建进程、查看进程进程的状态以及进程的优先级

前言 本文介绍了创建进程、查看进程进程的状态以及进程的优先级相等关概念 一、初识fork 通过系统调用fork创建进程。...,一次要将子进程的pid返回给父进程,而子进程不需要) 3.将子进程进程执行的任务分离 根据父子进程的返回值不同: 文件test.c 运行结果: 4.多进程并行 文件test.c...4.僵尸进程(Z) 1.僵尸状态概念 一个小栗子 一天,张三在路上跑步,突然路边有一个人死亡了,张三立刻打电话给警察局,那么在这个路人死亡的那一瞬间直到警察查明他的信息以及死亡原因的这一过程就相当于处于僵尸状态...2.查看系统进程Linux/Unix系统中,用ps -la命令可以查看进程的信息。...4.修改进程的优先级 在Linux中修改进程的优先级是通过修改PRI和NI。也就是说,进程的优先级是受到nice值的影响的,但是默认情况下nice值为0.

35530

Spring MVC 原理探秘 - 容器的创建过程

2.1 业务容器的创建过程 前面说了一些背景知识作为铺垫,那下面我们开始分析容器的创建过程吧。按照创建顺序,我们先来分析业务容器的创建过程。...2.2 Web 容器的创建过程 前面说了业务容器的创建过程,业务容器是通过 ContextLoaderListener。那 Web 容器是通过什么创建的呢?...总的来说,Web 容器的创建过程和业务容器的创建过程大致相同,但是差异也是有的,不能忽略。...3.总结 本篇文章对 Spring MVC 两种容器的创建过程进行了较为详细的分析,总的来说两种容器的创建过程并不是很复杂。...MVC 更新时间 标题 2018-06-29 Spring MVC 原理探秘 - 一个请求的旅行过程 2018-06-30 Spring MVC 原理探秘 - 容器的创建过程

65630

linux进程进程间通信_linux共享内存进程间通信

内存共享最新整理: Linux进程间通信-共享内存 – 码到城攻共享内存可以说是最有用的进程间通信方式,也是最快的IPC形式 https://www.codecomeon.com/posts...二、相关函数: 信号量一样,在Linux中也提供了一组函数接口用于使用共享内存,而且使用共享共存的接口还与信号量的非常相似,而且比使用信号量的接口来得简单。...1、shmget函数 该函数用来创建共享内存,它的原型为: int shmget(key_t key, size_t size, int shmflg); 1.第一个参数,信号量的semget...2.第二个参数,size以字节为单位指定需要共享的内存容量 3.第三个参数,shmflg是权限标志,它的作用open函数的mode参数一样,如果要想在key标识的共享内存不存在时,创建它的话,可以...共享内存的权限标志文件的读写权限一样,举例来说,0644,它表示允许一个进程创建的共享内存被内存创建者所拥有的进程向共享内存读取和写入数据,同时其他用户创建进程只能读取共 享内存。

4.5K30
领券