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

探索进程和子进程

: 通过getpid()得到PID和ps指令获取进程PID是一致,都是5258 一个进程属性中,除了有自己进程PID还有进程PID,ps指令中查询到PPID是当前进程进程PID,可以是用函数...>0时,执行进程,当id==0时,执行子进程。...在代码中,fork函数返回值我们用变量id来接收:pid_t id=fork(),为什么id可以同时有两个值? 在任何平台,进程在运行时候都是具有独立性。...子进程可以把进程数据全被拷贝一份,但是大部分数据对于子进程来说可能都是没用,这就造成了浪费,所以操作系统只是把进程中数据层面的代码临时拷贝一份给子进程,即子进程创建后,会共享进程代码和数据,...变量id接收值是fork函数返回值,进程return一次,子进程return一次,子进程会执行写时拷贝,所以变量会有两个返回值,本质上是有两块空间。

7510

进程ID进程关系

进程ID 进程相关 ID 有多种,除了进程标识 PID 外,还包括:线程组标识 TGID,进程组标识 PGID,回话标识 SID。...TGID/PGID/SID 分别是相关线程组长/进程组长/回话 leader 进程 PID。 下面分别介绍这几种ID。 PID 进程总是会被分配一个唯一标识它们进程ID号,简称 PID。...由进程创建所有线程都有相同线程组ID(TGID)。线程有自己 PID,它TGID 就是进程主线程 PID。如果进程没有使用线程,则其 PID 和 TGID 相同。...因此进程还可以注册 SIGCHLD 信号处理函数,异步回收资源。 如果进程提前结束,那么子进程将把1号进程 init 作为进程。总之,进程都有进程,负责进程结束后资源回收。...在子进程退出且进程完成回收前,子进程变成僵尸进程。僵尸进程持续时间通常比较短,在进程回收它资源后就会消亡。如果进程没有处理子进程终止,那么子进程就会一直处于僵尸状态。

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

进程和子进程谁先运行?

Linux中,进程和子进程是并行运行,先运行哪个是不确定,在小红帽系统(Red Hat)中,先运行是子进程,在ubuntu系统中,进程是先运行。...其实谁先运行不重要了,一般在编程中,把进程当做守护进程使用,用一个waitpid(pid,&status,0) != pid 等待子进程结束,进程一直阻塞在这个函数中。...Child process ID: %d\n", pid); } return 0; } 结果(Ubuntu中):明显先打印了进程 ?...Child process ID: %d\n", pid); pid_wait = waitpid(pid, &status, 0); // 等待指定进程进程 printf("Child...\n", pid_wait); } return 0; } 结果(Ubuntu中):进程等待了子进程结束 ? 如果喜欢我文章,欢迎关注、点赞和转发,下面可以留言~~~

3.7K30

进程欺骗实践

文章前言 监控进程和子进程之间关系是威胁检测团队检测恶意活动常用技术,例如,如果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...2020/02/24/parent-pid-spoofing/ https://ired.team/offensive-security/defense-evasion/parent-process-id-ppid-spoofing

1.3K20

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

前言 子进程退出时候,进程能够收到子进程退出信号,便于管理,但是有时候又需要在进程退出时候,子进程也退出,该怎么办呢? 进程退出时,子进程会如何?...17433进程id是17432,但是在10秒后,它进程变成了1658。...另外还可以观察到,该进程也是其他系统进程进程。 如何确保进程退出同时,子进程也退出? 既然如此,如何确保进程退出同时,子进程也退出呢?...内容很多,主要意思为:设置一个信号,当进程退出时候,子进程将会收到该信号。 那么根据这个,我们完全可以在进程退出时,也给子进程一个退出信号。...因此,在最初fork子进程时候,便表明了,当进程退出时候,子进程收到SIGKILL信号,最终也退出。以此达到同生共死目的。

11.5K21

Fork进程后,是否与进程共享stdio?

今天想到一个问题:如果我在代码里面,fork当前进程,然后两个进程都执行scanf(),那会发生什么?键盘输入数据是定向到哪个进程呢?...scanf("%c\n", &c); printf("parent process: %c\n", c); } } } 根据上面这串代码,进程和子进程都会调用...scanf,并打印自己读取到数据。...process: 4 child process: 5 parent process: 5 parent process: 6 child process: 6 child process: 可以看到,进程和子进程都读取了键盘数据...具体是哪一个进程获取到数据,则与进程调度有关。这提醒了我一点:多个进程同时读取同一个stdin的话,会造成获取到数据不完整问题。(这与stdin默认为tty这样字节设备特性有关)

13220

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

假设是a进程创建了b进程,那么a进程就是b进程进程。...IceSworld,Process Explorer等) 查看时,会发现提权进程进程是创建它进程,这是由于AIS利用了CreateProcessAsUser() API中一个新功能,这里新功能就是将提权进程进程设置成创建该进程进程...,假设我们利用一下该API,我们就能够将自己进程进程设置为随意进程(要提权绕过UAC鸽子注意了),假设把木马进程进程设置为 杀软 ID或者csrss.exe ,notepad.exe 等可信进程...就能能设置这个被创建进程进程,这里也仿照黑防上贴下部分代码: DWORD pid = 0; /* 依据进程名获取随意进程Id */ GetProcessIdByName(L"explorer.exe...假设你调试程序检測进程,直接用以上办法启动它,当然进程就是他检測同意进程喽, 这里启动时要注意是设置CREATE_SUSPEND 就是创建挂起,然后在创建后使用ResumeThread恢复就能够顺利调试了

1.5K30

php 多进程编程进程阻塞与非阻塞实例分析

本文实例讲述了php 多进程编程进程阻塞与非阻塞。分享给大家供大家参考,具体如下: php中进程阻塞,主要是进程等待子进程退出。 1.php代码如下: <?...pcntl_wait($status); } else { //这里是子进程空间 echo "进程ID: ", posix_getppid(), " 进程ID : ", posix_getpid...echo "进程ID: ", posix_getppid(), " 进程ID : ", posix_getpid(), " {$i} \r\n"; //我们让子进程等待3秒,再退出...status, WNOHANG); } else { //这里是子进程空间 echo "进程ID: ", posix_getppid(), " 进程ID : ", posix_getpid...代码3.php与2.php效果一样,pcntl_wait()函数作用只是用来让进程等待子进程退出,默认情况下会阻塞主进程

87141

Linux进程ID号--Linux进程管理与调度(三)【转】

,本篇文章只关注该数据结构如何来组织和管理进程ID。...进程ID概述 进程ID类型 要想了解内核如何来组织和管理进程ID,先要知道进程ID类型: 内核中进程ID类型用pid_type来描述,它被定义在include/linux/pid.h中: enum...系统中每个进程都对应了该命名空间一个PID,叫全局ID,保证在整个系统中唯一。 局部ID 对于属于某个特定命名空间,它在其命名空间内分配ID为局部ID,该ID也可以出现在其他命名空间中。...下文我将使用ID指代提到任何进程ID。在必要情况下,我会明确地说明ID类型(例如,TGID,即线程组ID)。 一个小型子系统称之为PID分配器(pid allocator)用于加速新ID分配。...内核是如何设计task_struct中进程ID相关数据结构 Linux 内核在设计管理ID数据结构时,要充分考虑以下因素: 如何快速地根据进程 task_struct、ID类型、命名空间找到局部ID

5.7K10

【Linux】解决:为什么重复创建同一个【进程pid会变化,而ppid进程id不变?】

本章主要内容面向接触过Linux老铁 主要内容含: 1.系统调用接口查看pid,ppid pid:当前进程 ppid:进程 每一次启动进程, 系统会重新生成pid ,系统只保证当前生命周期内...pid有效; 但是 进程不会变 2.为什么ppid进程id不变?...——bash命令行解释器与bash进程 当我们运行一个进程时,命令行解释器会把这个指令解释成bash进程 接着再由这个bash进程执行对应命令 当这个子进程出现问题时,并不影响bash进程...即:每一条命令被执行,都属于bash进程 我们执行一段代码,parent对应是getppid()函数; 我们接着用ps+grep过滤指令查看这个16815进程,发现其就是bash进程

9110

8.7 进程检测反调试

首先这是一种比较奇特反调试思路,通过检测自身进程来判定是否被调试,原理非常简单,我们系统在运行程序时候,绝大多数应用程序都是由Explorer.exe这个进程派生而来进程,也就是说如果没有被调试其得到进程就是...Explorer.exe进程PID,而如果被调试则该进程进程PID就会变成调试器PID值,通过对进程检测即可实现检测是否被调试功能。...PROCESSENTRY32); Process32First(hProcessSnap, &pe32); do { // 先判断是不是我们自己进程...PID if (ProcessId == pe32.th32ProcessID) { // 判断进程是否是 Explorer.exe...} return FALSE;}int main(int argc, char * argv[]){ if (IsDebug()) { printf("[-] 进程正在被调试

20530

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

白发人送黑发人 一个普遍常识是,在Linux里面总是“白发人送黑发人”,子进程死亡,进程透过wait()等待子进程死亡,并清理子进程僵尸,当然进程也可以因此而获得子进程死亡原因。.../a.out child process id: 3320 然后用信号2去杀死这个子进程3320: kill -2 3320 进程waitpid()返回,然后status里面获知原因,进程打印:...则进程探测到子进程死亡后,可打印它退出状态: $ ..../a.out child process id: 3362 child process exits, status=1 由此可以看出,进程对子进程死亡和死亡原因是了如指掌。 ?...事出必有因 那么,进程为什么必须知道子进程死亡呢?进程为什么一定要苦苦地知道子进程死亡原因?

2K20

8.7 进程检测反调试

首先这是一种比较奇特反调试思路,通过检测自身进程来判定是否被调试,原理非常简单,我们系统在运行程序时候,绝大多数应用程序都是由Explorer.exe这个进程派生而来进程,也就是说如果没有被调试其得到进程就是...Explorer.exe进程PID,而如果被调试则该进程进程PID就会变成调试器PID值,通过对进程检测即可实现检测是否被调试功能。...PROCESSENTRY32); Process32First(hProcessSnap, &pe32); do { // 先判断是不是我们自己进程...PID if (ProcessId == pe32.th32ProcessID) { // 判断进程是否是 Explorer.exe...return FALSE; } int main(int argc, char * argv[]) { if (IsDebug()) { printf("[-] 进程正在被调试

17520

如何获得Docker容器进程ID?

开始之前 在某些情况下,比如系统负载很高 docker stop 无法关闭某个容器(无响应),这时可以根据容器进程ID找到宿主机进程ID,然后强制kill掉这个容器,最好已经使用了数据卷保证数据持久化...获得容器进程ID docker inspect -f '{{ .State.Pid }}' web 9834 3....最后如有必要可以kill这个进程ID,这等于强制杀掉容器进程。 kill -9 9834 容器进程 内容摘自 > 一书。...容器实质是进程,但与直接在宿主执行进程不同,容器进程运行于属于自己独立命名空间。因此容器可以拥有自己 root文件系统、自己网络配置、自己进程空间,甚至自己用户 ID空间。...小结 最后来总结下文章中知识点 Docker容器本质上是宿主机上进程。 容器进程ID就是宿主机进程ID,因为它们是相同

5.5K10
领券