首页
学习
活动
专区
工具
TVP
发布

Linux 创建进程执行任务的实现方法

Linux 操作系统紧紧依赖进程创建来满足用户的需求。例如,只要用户输入一条命令,shell 进程创建一个新进程,新进程运行 shell 的另一个拷贝并执行用户输入的命令。...Linux 系统中通过 fork/vfork 系统调用来创建进程。本文将介绍如何使用 fork/vfork 系统调用来创建进程并使用 exec 族函数在新进程中执行任务。...通常将原有的进程称为父进程,把新创建进程称为进程进程是父进程的一个拷贝,进程获得同父进程相同的数据,但是同父进程使用不同的数据段和堆栈段。...exec 族函数 使用 fork/vfork 创建进程后执行的是和父进程相同的程序(但有可能执行不同的代码分支),进程往往需要调用一个 exec 族函数以执行另外一个程序。...本文试图通过简单的 demo 来演示这些函数的基本用法,为理解 Linux 系统中父进程进程的概念提供一些直观的感受。

3.7K11

subprocess:Python中创建进程

前言 subprocess库提供了一个API创建进程并与之通信。这对于运行生产或消费文本的程序尤其有好处,因为这个API支持通过新进行的标准输入和输出通道来回传数据。...returncode为进程的退出状态码。通常情况下,退出状态码为0则表示进程成功运行了;一个负值-N表示这个子进程被信号N终止了。...该函数还有许多参数,比如shell,默认值为False表示直接运行命令,如果主动赋值为True则会创建一个中间shell进程,由这个进程运行命令。...这就是subprocess库创建进程的通信机制) 需要注意的是,如果需要抑制输出效果,可以将stdout与stderr设置为subprocess.DEVNULL。...连接管道段 在Linux系统中,我们可以将多个命令连接成一个管线,即可以把它们的输入输出串联在一起。

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

linux:根据主进程查找进程

本文链接:https://blog.csdn.net/10km/article/details/100603320 如下是我的项目中创建的一个java系统服务在通过systemctl status显示的服务状态...,进程ID分别为1088,1482,1494,从左到右为父/进程关系.如果想通过netstat命令根据PID查找服务所占用的端口,就需要最右的java进程ID。...怎么样通过这个MainPID获取实际工作的进程ID呢,ps的 -g选项可以根据PID过程要显示的所有属于指定PID的进程进程,比如: $ ps --forest -o pid,cmd -g 1088...target/start_facelog_server.sh 1494 \_ java -jar facelog-service-2.4.2-standalone.jar 最后一行就是最后的进程...main_pid="$(systemctl show $service_name --property=MainPID)" main_pid=${main_pid##*=} # ps 命令获取最下层的进程

4.8K20

Linux系统进程编程之回收进程(三)

那么说了这么多,我们该怎么样来回收Linux系统的僵尸进程呢?...返回值是进程的ID,当前父进程有可能有多个子进程,wait函数阻塞直到其中一个进程结束wait就会返回,wait的返回值就可以用来判断到底是哪一个进程本次被回收了: wait(): on success...#include 7 static void sig_child(int signo); 8 9 int main() 10{ 11 pid_t pid; 12 //创建捕捉进程退出信号...此时如果父进程执行waitpid时进程已经先结束等待回收则waitpid直接回收成功,返回值是回收的进程的PID; 如果父进程waitpid时进程尚未结束则父进程立刻返回(非阻塞),但是返回值为...上面的源代码链接:https://github.com/1121518wo/linux-/tree/master

3.1K20

Linux系统编程】通过系统调用获取进程标识符 及 创建进程(fork)

bash创建进程去帮它执行命令,那下一个问题,如何创建进程呢? 3....那这也证实了它们两个是父子进程关系,fork的作用就是创建当前进程进程,而PID为30455的这个进程就是被创建进程。...,它肯定跟前面那个相同,因为执行第一个打印的时候还没有执行fork()创建进程呢。...失败的话,-1在父进程中返回,不会创建任何进程,并且正确设置了errno(C语言中一个用于表示错误码的全局变量,Linux内核是C语言写的)。 也就是说fork成功的话,返回值会有两个。...那这样就做到了在数据层面上也可以实现进程间的独立性。 所以,可以理解为: 当进程创建时,起初操作系统只为其分配一个新的进程控制块(PCB),用于维护进程的相关信息。

14810

Linux进程与可执行程序的关系&&fork创建进程&&写实拷贝的理解

二、通过系统调用创建进程 fork:创建进程 fork之后有两个执行分支,fork之后代码共享,也就是说fork之后的代码父进程进程都会执行。下面的5986进程就是bash进程。...原因是在进程中,一个父进程可能会有多个子进程,父进程想要管理进程必须通过进程的标识符,所以父进程必须知道子进程的标识符,而进程只需要关心自己是否成功创建了,所以返回0。...这和linux中的虚拟地址有关,也就是说,一个变量可以指向不同的地址空间。 写实拷贝 任意进程之间是具有独立性的,不会互相影响。...创建一个进程的时候,系统中就会多一个进程,当进程创建时,系统就必须为进程创建出一个全新的PCB(task_struct),父进程会把自己PCB中很多内容拷贝给进程的PCB,也就是说,进程创建,...进程都有自己的代码和数据,系统创建出来的进程的PCB默认就会指向父进程的代码和数据,想让父子进程分别执行不同的程序,那就可以在代码中根据父子进程fork返回值的不同设置ifelse语句,让父子进程分别执行不同的代码

1200

php中pcntl_fork创建进程

一、php中pcntl_fork函数概述 pcntl_fork()函数是php中用于创建进程的一个函数,返回创建进程的pid。...该函数创建进程具体fork的过程: (1)调用该函数即创建一个进程创建成功父进程返回进程的pid,进程返回0; (2)创建进程实际上对父进程的一个拷贝,共享代码空间,拷贝父进程的数据,也就是说父进程改变父进程的数据...$curr_pid.PHP_EOL; //开始创建进程 $son_pid = pcntl_fork();//返回进程的id //查看当前进程 echo '创建进程之后当前的进程为...示例代码分析: (1)发现创建进程之后,系统会切换到进程中,而进程中的代码是从含有pcntl_fork函数的那行执行的 (2)创建进程之后,进程的代码段是拷贝pcntl_fork函数及之后的代码段...例如监控工具,想要监控几个不同指标的情形,可以使用主进程监控各指标的配置变化,然后对每个指标分别fork一个进程来监控其具体的情形,当主进程发现指标的配置改变则kill掉之前的进程重新创建进程进行监控

86721

Linux创建进程

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

2.1K10

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

一.进程创建 fork函数创建进程,新进程进程,原进程为父进程; fork函数包含在头文件 进程调用fork,当控制转移到内核中的fork代码后,内核做: 分配新的内存块和内核数据结构给进程...将父进程部分数据结构内容拷贝至进程 添加进程到系统进程列表当中 fork返回,开始调度器调度 关于fork函数的返回值: 返回0给进程 返回进程的PID给父进程 创建失败,返回值 < 0 进程和父进程共享...进程替换的原理: 进程在替换时,只会替换掉物理内存中原来程序的代码和数据,其它的并不会动,且调用exec并不创建进程,所以调用exec前后该进程的id并未改变。...因为创建进程的时候,环境变量已经被子进程继承下去了,所以进程替换不会替换环境变量。...因为在linux中,环境变量的内容是在一个区域放着的,而环境变量表 env 中存的是环境变量的地址,这些地址指向所对应的环境变量;         而我们putenv一个环境变量时,其实是在环境变量表中找一个未使用的下标

16010

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

环境:centos7.6,腾讯云服务器 Linux文章都放在了专栏:【Linux】欢迎支持订阅 相关文章推荐: 【Linux】冯.诺依曼体系结构与操作系统 【Linux进程理解与学习Ⅰ-进程概念...【Linux进程理解与学习Ⅱ-进程状态 【Linux进程理解与学习Ⅲ-环境变量 【Linux进程理解与学习Ⅳ-进程地址空间 浅谈Linux下的shell--BASH 【Linux进程优先级...进程创建 再谈fork函数 #include pid_t fork(void); 返回值:创建进程成功后,给进程返回0,父进程返回进程的pid,出错返回-1 pid_t...我们在Linux下可以通过echo $?指令查看最近的进程的退出码。 ​...僵尸进程(Z) 对于父进程来说,进程的执行结果是否正确并不重要,重要的是进程的退出状态,即进程是否是正常退出。而进程的执行结果是否正确则是由程序员根据退出码自行判断。

3.3K40

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

下,创建一个 进程进程 创建后,会为其分配新的内存块和内核数据结构(PCB),将 父进程 中的数据结构内容拷贝给 进程,同时还会继承 父进程 中的环境变量表 进程具有独立性,即使是父子进程,也是两个完全不同的进程...,返回 -1 进程创建成功后 给进程返回 0 给父进程返回进程的 PID 值 通过代码理解 进程 创建 #include #include #include...if(id1 == 0) { //进程创建成功,创建孙子进程 pid_t id2 = fork(); if(id2 == 0) { printf("我是孙子进程...,退出 } 观察结果不难发现,两个子进程已经成功创建,但最晚创建进程,总是最先运行,这是因为 fork 创建进程后,先执行哪个进程取决于调度器 得到进程后,此时可以在一个程序中同时执行两个进程...---- 总结 以上就是关于 Linux进程控制(创建、终止、等待) 的相关知识了,我们学习了 进程 是如何被创建的,创建后又是如何终止的,以及 进程 终止 父进程 需要做些什么,有了这些知识后,

18810

Linux创建进程达到65535的方法

Linux创建进程据说消耗很少,这个一直是Linux的特点,于是就专门测试Linux创建进程的极限,测试代码如下: //fork.c #include #include <stdlib.h...", count); } for (count = 0; count < MAXPROCESS; count++) { wait(); } exit(0); } 这段代码是不断创建进程.../fork 我的虚拟机Linux内存是512M,在创建6千多个进程时,程序运行得很慢,通过vmstat命令观察,发现swap内存的置入置出很频繁,可以判断是由于内存不足,使用虚拟内存,导致频繁的IO操作...测试代码中,创建进程,占用的内存相当小,实际使用中,只可能比测试代码创建进程使用更多的内存,所以相应的,同样配置的机器,能创建的可用进程应该是更少的。...总结 以上所述是小编给大家介绍的Linux创建进程达到65535的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对ZaLou.Cn网站的支持!

1.6K31

Linux创建进程达到65535的方法

Linux创建进程据说消耗很少,这个一直是Linux的特点,于是就专门测试Linux创建进程的极限,测试代码如下: //fork.c #include  #include <stdlib.h...", count);   }   for (count = 0; count < MAXPROCESS; count++) {     wait();   }   exit(0); } 这段代码是不断创建进程...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_VM标志创建了一个新进程。...这使得进程能继承父进程的文件系统环境,可以从相同的目录访问相同的文件。...CLONE_FILES CLONE_FILES标志将使新进程共享与父进程相同的文件描述符表,这意味着它们将共享打开的文件。进程可以在没有另一个打开文件描述符的情况下访问它们。

13210

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

平时写过多进程多线程程序,比如使用linux的系统调用fork创建进程和glibc中的nptl包里的pthread_create创建线程,甚至在java里使用Thread类创建线程等,虽然使用问题不大...这次在自己写操作系统的时候,看了一遍linux内核的进程创建过程。算是有了比较深入的理解。     进程概念:进程是对正在运行程序的一个抽象。...group_leader是新进程本身,pgid是当前进程创建进程进程)的pgid,tgid是新进程本身,parent是当前进程创建进程进程)。...,则需要创建一个新的内存描述符,并将父进程的mm有关信息复制到进程 mm = dup_mm(tsk); if (!.../将父进程的内核栈帧结构复制给进程内核栈帧 childregs->eax = 0; //调用完毕后创建进程完毕后进程返回值 childregs->esp = esp; //进程的用户栈顶指针

8.5K21
领券