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

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

进程ID概述 进程ID类型 要想了解内核如何来组织和管理进程ID,先要知道进程ID的类型: 内核中进程ID的类型用pid_type来描述,它被定义在include/linux/pid.h中: enum...是 Linux 中在其命名空间中唯一标识进程而分配给它的一个号码,称做进程ID号,简称PID。...(轻量级进程组)的ID标识 在一个进程中,如果以CLONE_THREAD标志来调用clone建立的进程就是该进程的一个线程(即轻量级进程Linux其实没有严格的进程概念),它们处于一个线程组,该线程组的所有线程的...内核是如何设计task_struct中进程ID相关数据结构的 Linux 内核在设计管理ID的数据结构时,要充分考虑以下因素: 如何快速地根据进程的 task_struct、ID类型、命名空间找到局部ID...这也就解决了上面的第3个问题——如何快速地分配一个全局的PID 如何快速地根据进程的 task_struct、ID类型、命名空间找到局部ID 至于上面的第1个问题就更加简单,已知 task_struct

5.8K10

初识Linux · 进程1

前言: 都说类和对象是C++中的第一个里程碑节点,那么Linux系统编程部分的第一个里程碑节点就是进程的引入,可以说我们前面的所有学习,都没有真正的开始学习Linux,我们只不过是从0开始了解一个新的软件的最基本使用而已...,我们现在开始了解的是更深层次的东西,所以学习进程之前,我们应该具备一定的预备知识,所以本文注重的是预备知识,后面再介绍进程。...1 冯诺依曼体系 这位科学家是一位十分伟大的科学家->冯诺依曼,是他创建了冯诺依曼体系,让计算机跨越了一个新的时代,那么什么是冯诺依曼结构体系呢?...不要忘记了,操作系统是可以直接杀死进程或者直接回收进程的。 所以我们应该尝试理解操作系统。...从概念上看,我们在最开始已经介绍了操作系统是一个软件,进行软硬件资源管理的软件,那么在Linux最开始的部分,我们知道从广义上来看,操作系统不仅包括了操作系统的内核,还包括了外壳程序(使用户不能直接进行访问操作系统内核的

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

    linux-进程1

    1.冯诺依曼体系结构 在讲解进程之前,要先知道什么是冯诺伊曼体系结构。冯诺依曼体系结构是如今最主流的体系结构,所有的硬件可以分为5大单元,单元之间存在交互。...那么在cpu计算数据1的时候,数据2已经通过输入设备加载到了存储器,这就是预加载,在cpu计算数据2的时候,数据1已经被存放在了存储器,输出设备需要的时候就直接从存储器拿,这就是缓存,通过预加载和缓存就能提高计算机的效率...课本上称之为PCB(process control block), Linux操作系统下的PCB是: task_struct 4.2.1task_struct-PCB的一种 在Linux中描述进程的结构体叫做...task_struct是Linux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息 4.2.2task_ struct内容分类  标示符: 描述本进程的唯一标示符,用来区别其他进程...4.4查看进程 进程的信息可以通过 /proc 系统文件夹查看 如:要获取PID为1进程信息,你需要查看 /proc/1 这个文件夹 大多数进程信息同样可以使用top和ps这些用户级工具来获取 当我编译下面这段代码生成可执行程序时

    13110

    进程ID进程间的关系

    进程ID 进程相关的 ID 有多种,除了进程标识 PID 外,还包括:线程组标识 TGID,进程组标识 PGID,回话标识 SID。...TGID/PGID/SID 分别是相关线程组长/进程组长/回话 leader 进程的 PID。 下面分别介绍这几种ID。 PID 进程总是会被分配一个唯一标识它们的进程ID号,简称 PID。...pids[] 的数组下标是枚举类型,在 include/linux/pid.h 中定义了 PID 的类型: enum pid_type { PIDTYPE_PID, PIDTYPE_TGID,...因此父进程还可以注册 SIGCHLD 信号的处理函数,异步回收资源。 如果父进程提前结束,那么子进程将把1进程 init 作为父进程。总之,进程都有父进程,负责进程结束后的资源回收。...会话、进程组关系 Linux 系统中可以有多个会话(session),每个会话可以包含多个进程组,每个进程组可以包含多个进程

    60423

    Linux0号进程1进程,2号进程

    本节我们将从linux启动的第一个进程说起,以及后面第一个进程是如何启动1进程,然后启动2号进程。...0号进程linux启动的第一个进程,它的task_struct的comm字段为"swapper",所以也成为swpper进程。...在linux内核中为0号进程专门定义了一个静态的task_struct的结构,称为init_task。...通常来说ARM64是先运行EL3,再EL2,然后从EL2就trap到EL1,也就是我们的Linux内核。 我们来看下Linux内核启动的代码。...所以说所有的内核线程的父进程都是2号进程,也就是kthreadd。 总结: linux启动的第一个进程是0号进程,是静态创建的 在0号进程启动后会接连创建两个进程,分别是1进程和2和进程

    6.9K21

    Linux系列(四):我经常用下列命令查看进程id

    序号 001 查看端口被哪个进程占用 1. lsof -i:端口号, 查看某一端口的占用情况 [root@localhost bin]# lsof -i:8080 COMMAND PID USER FD...PID:进程ID,一般杀掉进程时就是指定进程的PID USER:进程所有者 2. netstat -ntlp:查看当前所有tcp端口 结合grep可以进一步查看具体端口号的占用情况 netstatstat...ID为3511的Java进程占用 [root@ops01 ~]# netstat -tunlp|grep 3000 tcp6 0 0 :::3000...:::* LISTEN 13298/node /u01/WSS 上述结果表示3000端口被一个进程ID为13298的node程序占用 序号 002 根据程序名称查看进程...id 1. ps -ef|grep 进程名 ps -ef 是显示所有进程 UID:进程拥有者 PID:进程ID PPID:上级父程序的ID C: CPU 使用的资源百分比 STIME:系统启动时间

    2.3K10

    如何获得Docker容器进程ID?

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

    5.8K10

    Linux进程调度之 - O(1)调度算法

    Linux是一个支持多任务的操作系统,而多个任务之间的切换是通过 调度器 来完成,调度器 使用不同的调度算法会有不同的效果。...而Linux2.6开始替换成名为 O(1)调度算法,顾名思义,其时间复杂度为O(1)。...虽然在后面的版本开始使用 CFS调度算法(完全公平调度算法),但了解 O(1)调度算法 对学习Linux调度器还是有很大帮助的,所以本文主要介绍 O(1)调度算法 的原理与实现。...由于在 Linux 内核中,任务和进程是相同的概念,所以在本文混用了任务和进程这两个名词。...O(1)调度算法 把140个优先级的前100个(0 ~ 99)作为 实时进程优先级,而后40个(100 ~ 139)作为 普通进程优先级。

    4.8K81

    Linux1进程的前世(kernel_init)今生(init进程)----Linux进程的管理与调度(六)

    由0号进程创建1进程(内核态),1号内核线程负责执行内核的部分初始化工作及进行系统配置,并创建若干个用于高速缓存和虚拟主存管理的内核线程。...init进程 随后,1进程调用do_execve运行可执行程序init,并演变成用户态1进程,即init进程。 init进程linux内核启动的第一个用户级进程。...上述过程可描述为:0号进程->1号内核进程->1号用户进程(init进程)->getty进程->shell进程 注意,上述过程描述中提到:1号内核进程调用执行init函数并演变成1号用户态进程(init...因此,init总是第一个进程(它的进程号总是1)。...浅析 Linux 初始化 init 系统(1):sysvinit upstart debian, Ubuntu等系统使用的initdaemon 浅析 Linux 初始化 init 系统(2): UpStart

    3.8K11

    LinuxLinux进程控制>进程创建&&进程终止&&进程等待&&进程程序替换

    1.进程创建 1.1 fork函数 在linux中fork函数时非常重要的函数,它从已存在进程中创建一个新进程。...新进程为子进程,而原进程为父进程 #include pid_t fork(void); 返回值:自进程中返回0,父进程返回子进程id,出错返回-1 进程调用fork,当控制转移到内核中的...); 返回值: 当正常返回的时候waitpid返回收集到的子进程进程ID; 如果设置了选项WNOHANG,而调用中waitpid发现没有已退出的子进程可收集,则返回0; 如果调用中出错,则返回-...Pid>0.等待其进程ID与pid相等的子进程。 status: WIFEXITED(status): 若为正常终止子进程返回的状态,则为真。...(查看进程的退出码) options: WNOHANG: 若pid指定的子进程没有结束,则waitpid()函数返回0,不予以等待。若正常结束,则返回该子进 程的ID

    15310

    Android跨进程通信IPC之1——Linux基础

    由于Android系统是基于Linux系统的,所以有必要简单的介绍下Linux的跨进程通信,对大家后续了解Android的跨进程通信是有帮助的,本篇的主要内容如下: 1Linux介绍 1.1、Unix...2007年1月22日,OSDL和自由标准组织合并为Linux基金会,把它们的工作焦点集中在改进GNU/Linux以与Windows竞争。...三、Linux的跨进程通信详解 在Linux进程通信有以下七种: 1、匿名管道(pipe) 2、命名管道(FIFO) 3、信号(signal) 4、信号量(semaphore) 5、消息队列(message...信号是比较复杂的通信方式,用于通知接受进程有某种事件发生,除了用于进程间通信外,进程还可以发送信号给进程本身;Linux除了支持Unix早期信号语义函数sigal外,还支持语义服务Posix.1标准的信号函数...2、消息队列的原理及注意事项: 消息队列其实就是一个消息的链表,每个消息都有一个队列头,称为struct_msg_queue,这个队列头描述了消息队列的key值,用户ID,组ID等信息,但它存于内核中而结构体

    1.7K30
    领券