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

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

6.7K10

【Linux】进程(1)

这次带来的是Linux系统中关于进程这部分的一些知识点,如果对你有所帮助的话,可否留下你宝贵的三连呢?...操作系统内核四大功能:进程管理、文件管理、存储管理和驱动管理。能够发现,操作系统干的事情就是管理。...3.3 初步了解进程 在我们的操作系统内比如windows操作系统就能够同时运行多个程序,而运行程序第一步就是要把它们加载到内存里面。这也代表一定会同时存在多个进程。...操作系统是需要对这些进程进行管理的,操作系统管理的办法是先描述再组织,也就是先将该程序的数据属性用struct结构体包含描述起来,再将这些结构体组织起来形成数据结构来方便操作系统进行更好的管理。...进程不是加载到内存里面的程序(数据和代码),而是加载到内存里的程序+内核数据结构对象(task_struct),它们合起来才能被叫做进程。

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

    初识Linux · 进程(1)

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

    18410

    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这些用户级工具来获取 当我编译下面这段代码生成可执行程序时

    31810

    【Linux】进程(1)进程概念和进程状态

    在Linux下,我们在命令行输入的命令都是Bash(命令行解释器)的子进程。 1....示例如下: #include #include int main() { pid_t id = fork(); if(id == 0)//子进程...注:1 号进程(init 或 systemd) 是 Linux 系统中的第一个用户态进程,负责初始化系统并管理其他进程。它由内核在系统启动时创建,PID固定为 1。...现代 Linux 主要使用 systemd 作为 1 号进程,提供服务管理、日志收集和系统控制功能,而早期系统则使用 sysvinit 或 upstart。...如果 1 号进程崩溃,系统通常会进入不可用状态,需要重启。 那么为什么子进程会被1号进程领养呢?如果1号进程不领养它,则当子进程死亡后,没有父进程读取信息,就会造成内存泄漏。

    1.1K00

    进程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),每个会话可以包含多个进程组,每个进程组可以包含多个进程。

    1.6K23

    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和进程。

    7.8K21

    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.8K10

    【Linux系统】进程切换 | 进程调度——O(1)调度队列

    /* 进程ID */ long father, pgrp, session, leader; /* 父进程ID、进程组ID、会话ID、会话领导者ID */ unsigned short...uid, euid, suid; /* 用户ID、有效用户ID、保存的用户ID */ unsigned short gid, egid, sgid; /* 组ID、有效组ID、保存的组...Linux2.6内核进程O(1)调度队列 进程切换现在知道了,但是是如何进行调度的呢? 上图展示了Linux 2.6内核中进程队列的数据结构,下图用图示清晰地呈现了各组件间的关联关系,以便于理解。...进程优先级: 普通进程的优先级范围在 100 至 139 之间。在 Linux 系统中,与 nice 值相关联,nice 值越小,进程优先级越高。...2.6 总结 O(1) 调度算法: 在这种调度机制下,查找最优进程的时间复杂度为 O(1)。无论系统中有多少进程,调度器总能以固定时间成本找到合适的进程进行调度。

    23810

    如何获得Docker容器进程ID?

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

    6.5K10

    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)作为 普通进程优先级。

    5.6K81

    Linux下1号进程的前世(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

    4.5K11
    领券