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

Linux内核编程--进程和守护进程

进程组长(头部进程):每个进程都有一个进程ID, 每个进程都有一个组长(头部进程), 在大部分系统中, 进程ID一般就是头部进程ID。获得一个进程所在的进程ID用getpgid(pid)。...fork创建的进程和父进程在同一个进程中,进程的Leader必然是该的第一个进程,所以进程不可能是该的第一个进程,在进程中调用setsid就不会有问题了。...b.进程调用完此函数,会成为新会话的会话首进程(session leader),该进程会成为一个新进程的头部进程,新进程ID就是这个进程ID。 c.该进程没有控制终端。...进程继承了父进程进程ID,不过它有自己的进程ID,这就保证了进程不是一个进程的头部进程 Step.3 调用setsid( ),给守护进程创建一个新的进程和会话,使当前进程成为新进程的头部进程...查询被进程ID对应的进程打开的文件:lsof -p 1000 查看进程内存情况:pmap PID 样例: 参考阅读: 《UNIX环境高级编程第3版》 《Linux C++ 通信架构实战》 《UNIX

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

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

进程ID概述 进程ID类型 要想了解内核如何来组织和管理进程ID,先要知道进程ID的类型: 内核中进程ID的类型用pid_type来描述,它被定义在include/linux/pid.h中: enum...是 Linux 中在其命名空间中唯一标识进程而分配给它的一个号码,称做进程ID号,简称PID。...(轻量级进程)的ID标识 在一个进程中,如果以CLONE_THREAD标志来调用clone建立的进程就是该进程的一个线程(即轻量级进程Linux其实没有严格的进程概念),它们处于一个线程,该线程的所有线程的...进程ID叫做PGID,进程内的所有进程都有相同的PGID,等于该组组长的PID。 SID 几个进程可以合并成一个会话(使用setsid系统调用),可以用于终端程序设计。...带进程ID类型的task_struct设计 如果考虑进程之间有复杂的关系,如线程进程、会话,这些均有ID,分别为 TGID、PGID、SID,所以原来的 task_struct 中pid_link

5.7K10

进程ID进程间的关系

进程ID 进程相关的 ID 有多种,除了进程标识 PID 外,还包括:线程标识 TGID,进程标识 PGID,回话标识 SID。...TGID/PGID/SID 分别是相关线程组长/进程组长/回话 leader 进程的 PID。 下面分别介绍这几种ID。 PID 进程总是会被分配一个唯一标识它们的进程ID号,简称 PID。...由进程创建的所有线程都有相同的线程ID(TGID)。线程有自己的 PID,它的TGID 就是进程的主线程的 PID。如果进程没有使用线程,则其 PID 和 TGID 相同。...当一个进程创建了进程后,它应该通过系统调用 wait() 或者 waitpid() 等待进程结束,回收进程的资源。而进程在结束时,会向它的父进程发送 SIGCHLD 信号。...会话、进程关系 Linux 系统中可以有多个会话(session),每个会话可以包含多个进程,每个进程可以包含多个进程

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

C语言Linux系统编程-等待终止的进程(僵死进程

1.等待终止的进程(僵死进程): 如果一个进程在父进程之前结束,内核会把子进程设置为一个特殊的状态,处于这种状态的进程称为僵死进程 当父进程获取了进程的信息后,进程才会消失。...pid_t wait(int *status); 父进程调用这个方法会被阻塞住,如果子进程终止的时候,此方法会调用并且返回终止进程的pid #include #include <unistd.h...sleep(2); pid=getpid(); ppid=getppid(); printf("我是进程...,pid=22315 , ppid=12479 ,我新建的进程pid=22316 我是进程,pid=22316 , ppid=22315 我的进程,pid=22316,终止了 2.如果父进程进程之前终止了...,那么系统会把子进程设置给init进程(pid为1),init进程会周期性的等待所有的进程,确保没有长时间的僵死进程

3.4K20

Linux进程调度-调度及带宽控制

概述 调度(task_group)是使用Linux cgroup(control group)的cpu子系统来实现的,可以将进程进行分组,按来分配CPU资源等。...调度就可以解决这个问题,分别将A、B用户进程划分成组,并将两的权重设置成占比50%即可。...CFS调度器管理的是sched_entity调度实体,task_struct(代表进程)和task_group(代表进程)中分别包含sched_entity,进而来参与调度; 关于调度的相关数据结构...调度实体参与调度时,都会挂入到红黑树中,task_struct和task_group都属于被调度对象; task_group会为每个CPU再维护一个cfs_rq,这个cfs_rq用于组织挂在这个任务上的任务以及任务...sched_entity结构中存在parent指针,指向它的父结构,因此,系统的运行也能从下而上的进行遍历操作,通常使用函数walk_tg_tree_from进行遍历; 2.2 task_group权重 进程进程都有权重的概念

1.6K30

linux通过进程名杀死进程_linux关闭进程命令

笔记:根据一个进程的名字或启动此进程的命令(连续的一部分即可)杀死进程 一、使用单条命令 ps -ef | grep 进程名/启动进程的命令 | grep -v grep | awk ‘{print $2...}’ | xargs kill -9 执行结果: [1]-  已杀死               sleep 200 [2]+  已杀死               sleep 200 二、编写脚本 linux.../bin/bash # 脚本名:kill_process.sh # 脚本功能:强制杀死进程 方式kill -9     # 1通过ps查询进程id     # 2使用kill -9 强制终止进程...kill_processes(){     # 获取进程id     pids=$(ps -ef | grep “$1” | grep -v grep | grep -v $0 | awk ‘{...————————————————————— # 根据进程名查询包含进程名的进程 并排除grep查询进程和此脚本进程 ps -ef | grep “$pName” | grep -v grep | grep

15.8K20

L010Linux和androidNDK之linux避免僵尸进程进程退出的处理

L010Linux和androidNDK之linux避免僵尸进程进程退出的处理 如果你在程序中fork出一个进程,没有好好处理进程退出后的相关事宜,那么就有可能召唤出传说中进程界的僵尸---僵尸进程...,并不能将其完全销毁) 僵尸进程是怎么样产生 在Linux进程的状态中,僵尸进程是非常特殊的一种,它已经放弃了几乎所有内存空间,没有任何可执行代码,也不能被调度,仅仅在进程列表中保留一个位置,记载该进程的退出状态等信息供其他进程收集...异步回收僵尸进程: fork()之后,进程从父进程获取了一份拷贝,和父进程分别独立运行,僵尸进程的产生是因为父进程没有给进程“收尸”造成的,又可以根据危害程度分为下述两类: 总体来说:当进程结束之后...(1)当进程结束之后,但父进程未结束之前,进程将成为僵尸进程,父进程结束后僵尸被init进程回收。...pid=0 等待进程组识别码与目前进程相同的任何进程。 pid>0 等待任何进程识别码为 pid 的进程

3.1K40

wait() 回收进程

在前面的文章中我们讨论了如何通过 fork() 函数创建进程,创建后的进程如果优先于父进程退出,进程的虚拟内存空间就消失了,但是进程控制块PCB并没有消失,这里面包含了这个子进程的退出状态,需要由父进程来进行回收...在父进程回收之前,这个进程被称为僵尸进程(僵死进程),任何一个进程都会经过这段僵尸进程的阶段,最后由父进程来回收。...进程退出有两种情况,一种是程序正常退出了,比如exit(1)或者main函数返回等。而另外一种则是非正常退出,一般情况下是收到了某种信号,比如“kill -9”。...,如果返回真则证明子进程是正常退出的 if (WIFEXITED(status)) { // 打印已经退出的进程的 pid...而WIFSIGNALED则是判断进程是否是接收到了某个信号,如果是收到了某个信号证明进程是非正常退出的,那么使用WTERMSIG获取收到的信号。可通过 kill -l 查看信号编号的对应内容。

16930

Linux进程学习【进程状态】

进程 父子进程 相互独立,共享一份代码时,具有 写时拷贝 机制 阻塞 何为阻塞?...,即把手机揣进兜里,然后 专心执行走路这个 进程 进程状态 进程 有各种运行状态,方便OS进行管理,在 Windows 中,进程 状态是这样的 而在我们 Linux 中,新建、就绪、运行都可以看作...运行 R 这一个状态,所以比较清晰 而我们今天要学习的正是 Linux 中的 进程 状态 进程是何种状态,取决于此进程的PCB在哪里排队 ️运行 R 首先来看看第一种状态 R 以我们以往的认知来说...僵尸 T 状态 通俗来说,僵尸状态 是给 父进程 准备的 当 进程 被终止后,会先维持一个 僵尸 状态,方便 父进程 来读取到 进程 的退出结果,然后再将 进程 回收 单纯的在 bash 环境下终止...父进程,此时 进程 会被OS领养 进程 的 父进程 变为 1号进程 进程 就变成了一个 孤儿进程 发出指令终止 父进程 假设 进程 不被 1号进程 领养 进程 退出时就会无人回收

18630

Linux进程学习【进程地址】

,使得进程和父进程共同使用一个变量 #include #include #include #include ...int main() { int val = 10; pid_t id = fork(); if(id == 0) { val *= 2; //刻意改变共享值 printf...,这种行为称为 写时拷贝 刚开始,父子进程共同使用同一块空间 当进程修改共享值后 ---- 进程地址空间 下面来好好谈谈 进程地址空间 (虚拟地址) ️虚拟地址 在早期程序中,是没有虚拟地址空间的...因为每个进程都有属于自己的空间,OS 在管理进程时,能够以统一的视角进行管理,效率很高 光有 虚拟地址空间 是不够的,还需要一套完整的 ‘‘翻译’’ 机制进行程序寻址,如 Linux 中的 页表 +...(权限设置) 将 进程管理 和 内存管理 进行 解耦,方便 OS 进行更高效的管理 可以让进程以统一的视角看待自己的代码和数据 ---- 总结 以上就是本篇关于 Linux进程学习【进程地址】的全部内容了

14220
领券