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

Linux进程概念(二.查看进程进程进程进程状态详解)

2.进程进程 2.1介绍 在操作系统中,当一个进程(称为进程)创建另一个新进程(称为进程)时,父子进程之间建立了一种特殊的关系。...PID关系: 进程的PID(进程标识符)是由进程调用fork()或类似系统调用创建的。 进程的PPID(进程标识符)创建它的进程的PID相同。...在Unix/Linux系统中,可以使用 getpid() 系统调用来获取当前进程的PID,使用 getppid() 系统调用来获取当前进程进程的PID。...下面是对这两个返回值的解释: 给进程返回进程的 PID:在进程中,fork 返回新创建进程进程 ID(PID),这个 PID 是进程的标识符,进程通过这个 PID 可以识别并操作进程。...为了区分进程进程,fork 在进程中返回 0,表示这是进程执行的代码路径。

1.4K10

探索进程进程

进程进程 这个进程PID到底是什么?...先来认识一下fork函数: fork函数会以调用该函数的进程作为进程创建一个进程 创建成功时,会在进程中返回进程的PID,在进程中返回0;如果失败,在进程中返回-1,没有进程创建。...一个进程可以创建多个子进程,为了区分这些进程,fork函数在创建进程后,会给进程返回进程的pid。进程只需调用getppid()函数即可找到进程。...进程进程也是两个进程,也具有独立性,父子进程不能访问同一份数据,数据在代码执行过程中可能会被修改。所以进程要把进程的数据单独拷贝一份,这个过程是由操作系统来完成的。...进程可以把进程的数据全被拷贝一份,但是大部分数据对于进程来说可能都是没用的,这就造成了浪费,所以操作系统只是把进程中数据层面的代码临时拷贝一份给进程,即进程创建后,会共享进程的代码和数据,

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

    进程退出时如何确保进程退出?

    前言 进程退出的时候,进程能够收到进程退出的信号,便于管理,但是有时候又需要在进程退出的时候,进程也退出,该怎么办呢? 进程退出时,进程会如何?...一般情况下,进程退出后,是不会通知进程的,这个时候进程会成为孤儿进程,最终被init进程收养。我们先来看一下这种情况。...另外还可以观察到,该进程也是其他系统进程进程。 如何确保进程退出的同时,进程也退出? 既然如此,如何确保进程退出的同时,进程也退出呢?...内容很多,主要意思为:设置一个信号,当进程退出的时候,进程将会收到该信号。 那么根据这个,我们完全可以在进程退出时,也给进程一个退出的信号。...总结 有些情况下,我们常常需要父子进程共存亡,进程退出时,进程可以通过wait捕捉进程的退出状态,但是进程退出时,进程却难以得知。

    12.2K21

    关于进程进程的关系(UAC 绕过思路)

    假设是a进程创建了b进程,那么a进程就是b进程进程。...,假设我们利用一下该API,我们就能够将自己的进程的的进程设置为随意进程(要提权绕过UAC的鸽子注意了),假设把木马进程进程设置为 杀软 的ID或者csrss.exe ,notepad.exe 等可信进程...假设你调试的程序检測进程,直接用以上的办法启动它,当然进程就是他检測同意的进程喽, 这里启动时要注意的是设置CREATE_SUSPEND 就是创建挂起,然后在创建后使用ResumeThread恢复就能够顺利调试了...所以说进程进程不一定是进程的创建者,所以那一群依据进程来看进程是否可信的杀软就呵呵了。 可是这里说下 360 这个绕只是,原因是啥哪? 记得我开篇时说过道高一尺,魔高一丈吗?...用这样的办法推断进程才是真正的进程。 这里參考文献是杂志《黑客防线》。我也不想学习了知识装起来。所以学习始终是学无止境!

    1.6K30

    Linux进程——Linux进程进程优先级

    所以,只要子进程退出,进程还在运行,但进程没有读取进程状态,进程进入Z状态 僵尸状态就是Linux状态中的X死亡状态!...可进程如果一直不读取,那进程就一直处于Z状态!...开个玩笑,孤儿进程进程进程退出之前就先退出了,此时的进程就称为“孤儿进程” 但是前面刚刚讲过一个进程在死亡时,PCB的死亡信息必须被读取后,才会释放PCB,但是如果进程已经退出了,进程的...进程进程退出了,进程要被领养,变成孤儿进程,而通过视频我们发现孤儿进程全部被1号进程统一领养了。...总结 本篇文章前部分紧贴上篇Linux进程,分析完了Linux下常见的进程状态,然后初步了解了Linux进程优先级,而进程优先级前面内容相差较大,希望大家能够多花点时间理解!

    10110

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

    wstatus用来返回进程结束时的状态,进程通过wait得到wstatus后就可以知道子进程的一些结束状态信息。...二、第二招:发送SIGCHILD信号: 1、我们还可以发送SIGCHILD信号来防止产生僵尸进程,当进程退出时向进程发送SIGCHILD信号,进程处理SIGCHILD信号,然后用上面信号处理函数中调用...第二个参数表示返回的状态;第一个表示选择性来指定返回的进程的ID: ---pid == -1 等待任一进程。于是在这一功能方面waitpidwait等效。...---pid > 0 等待其进程I Dp i d相等的进程。 ---pid == 0 等待其组I D等于调用进程的组I D的任一进程。换句话说是调用 者进程同在一个组的进程。...此时如果进程执行waitpid时进程已经先结束等待回收则waitpid直接回收成功,返回值是回收的进程的PID; 如果进程waitpid时进程尚未结束则进程立刻返回(非阻塞),但是返回值为

    3.4K20

    Linux进程控制】五、wait()函数——进程回收

    僵尸进程孤儿进程 孤儿进程进程结束,进程被init进程收养。 僵尸进程进程结束,进程没有回收进程的资源(PCB),这个资源必须要由进程回收,否则就形成僵尸进程。...方法就是杀死进程进程被杀死后,由init接管子进程并回收进程资源。...进程调用wait()函数可以回收进程终止信息,wait()函数功能主要有三个:阻塞等待进程退出;回收进程残留资源;获取进程退出状态(退出原因)。...回收一个组的进程,使用时把组ID(一般是进程ID)传给pid参数,就可以使用waitpid()回收这个进程组的所有进程。...当waitpid()返回进程中后,进程才结束,但是waitpid()已经执行完了,所以并没有回收进程进程因此变成僵尸进程

    8310

    linux进程创建进程终止

    01.进程创建 #include pid_t fork(void); 返回值:自进程中返回0,进程返回进程id,出错返回-1 进程调用fork,当控制转移到内核中的fork代码后...,内核做: 分配新的内存块和内核数据结构给进程进程部分数据结构内容拷贝至进程 添加进程到系统进程列表当中 fork返回,开始调度器调度 写时拷贝 02.进程终止 首先想清楚,终止是做什么...: 释放曾经的代码和数据所占据的空间 释放内核数据结构 进程退出场景: 代码运行完毕,结果正确 代码运行完毕,结果不正确(这两点可以通过进程退出码判断) 代码异常终止 上面的代码,进程11258为进程...,进程获取到的是最近一个进程退出的退出码,前面我们提到,echo是内建命令,打印的都是bash内部的变量数据 进程bash为什么要得到进程的退出码呢?...这个退出码是一个整数,传递给进程,用于表示进程的终止状态。 常见惯例: 0(EXIT_SUCCESS):通常表示成功。程序执行完成且没有错误。

    9310

    Linux进程概念进程状态

    \n"); } return 0; } 可以看到,结果和我们预期一样,进程的 ppid 是 进程的 pid,进程的 ppid 是 bash,同时,对于进程,fork 函数返回进程的...1125之后,由于进程中没有对子进程的退出状态代码进行读取,所以进程变成了 Z 状态,并且进程后面还提示了 defunct (失效的,不再使用的),此时,如果进程一直不对不对子进程进行读取,那么子进程就会变成僵尸进程...2、孤儿进程 孤儿进程是指进程提前退出后,进程被操作系统领养的一种情况,被操作系统领养的进程就被称为孤儿进程; 这里还有两个细节:第一,进程退出后并没有变成Z状态,因为进程进程是bash...,bash会读取进程的退出状态;第二,进程被领养后变成了后台进程。...,所以我们需要指定优先级来合理的分配资源; Linux中优先级的特点 Linux 中优先级的表示维护通过两个变量 PRI (priority) 和 NI (nice) 来完成,每个进程默认的 PRI

    5.6K00

    进程欺骗实践

    文章前言 监控进程进程之间的关系是威胁检测团队检测恶意活动的常用技术,例如,如果powershell是进程,而Microsoft Word是进程,这是一种折中的行为,各种EDR可以很容易地检测到这种异常活动...,这时红队可以考虑使用进程PID欺骗作为逃避方法,Windows API调用"CreateProcess"允许用户传入一个用于分配PID的参数,它可以用于指定当前进程进程。...项目介绍 https://github.com/Al1ex/SelectMyParent image.png 进程欺骗 Step 1:选择进程并确定其PID image.png Step 2:之后执行以下命令进行进程欺骗...SelectMyParent.exe notepad 928 image.png Step 3:使用process Explor查看进程树,可以看到成功欺骗 image.png 参考链接 https

    1.4K20

    Linux进程间关系守护进程

    --- 乌龟大师 《功夫熊猫》--- 进程间关系守护进程 1 进程组 2 会话 3 控制终端 4 作业控制 5 守护进程 1 进程组 之前我们提到了进程的概念, 其实每一个进程除了有一个进程 ID...每当我们通过Xshell客户端正确的登录到Linux系统后,系统会给我们创建一个终端文件,并且配套一个bash进程进程组的形式)!我们写的命令写入到终端文件,然后通过bash进程执行在返回结果。...我们在下边详细介绍一下: 一个会话可以有一个控制终端, 通常会话首进程打开一个终端(终端设备或伪终端设备) 后, 该终端就成为该会话的控制终端。 建立控制终端连接的会话首进程被称为控制进程。...4 作业控制 作业在Linux环境中,是指为完成用户指定任务而启动的一组进程。一个作业可能仅包含单一进程,也可能由多个相互协作的进程构成,这些进程通常通过管道机制进行通信。...设置让自己成为一个新的会话, 后面的代码其实是进程在走 setsid(); // 4.

    12010

    Nodejs进程

    默认情况下, stdin、 stdout 和 stderr 的管道会在 Node.js 进程和衍生的进程之间建立,这些管道的容量是有限的。...child_process.fork(): 衍生新的 Node.js 进程,并调用指定的模块,该模块已建立了 IPC 通信通道,可以在进程进程之间发送消息。...process.pid} is running`) for( let i = 0; i < numsCPUS.length; i++) { cluster.fork() // fork出来的进程拥有和进程一致的...master进程创建一个socket,并绑定监听到该目标端口,通过进程之间建立IPC通道,调用进程的send方法,将socket(链接句柄)传递给进程,大致实现如下。...模式的区别 浏览器进程线程梳理 cluster进程重启方案 cluster 模块的实现原理

    1.3K20

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

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

    4.5K30

    Linux进程为何要苦苦地知道子进程的死亡原因?

    白发人送黑发人 一个普遍的常识是,在Linux里面总是“白发人送黑发人”,进程死亡,进程透过wait()等待进程死亡,并清理进程僵尸,当然进程也可以因此而获得进程的死亡原因。...上述代码中,进程在第18行通过pause()等待信号,进程在代码的第22行通过waitpid()等待进程的结束。其中的参数status是一个输出参数,可以获得进程死亡的原因。...则进程探测到进程死亡后,可打印它的退出状态: $ ....在wait_task_zombie()中,进程会透过进程的僵尸分析获得进程的exit_code组合,并进一步拼装status。 事出必有因 那么,进程为什么必须知道子进程的死亡呢?...所以,这个过程应该由Linux的某种机制自动完成,比如如果init知道了httpd死亡的话,它可以内在地自动重新启动一个httpd进程

    2.1K20
    领券