Linux 进程的基本概念及描述
目录
0.前言
1. 什么是进程
1.1 进程的定义与特性
1.2 进程与线程的区别
2.描述进程
2.1 PCB (进程控制块)
2.2 task_struct
3.查看进程
3.1 查看进程信息
3.1.1 /proc 文件系统
3.1.2 ps 命令
3.1.2 top 和 htop 命令
3.2 获取进程标识符
3.2.1使用命令获取PID
3.2.2 使用C语言程序获取PID
4. 通过系统调用创建进程
4.1 认识 fork
4.2 代码实践
5.小结
(图像由AI生成)
0.前言
在上一篇博客中,我们介绍了冯诺依曼体系结构与操作系统的基本概念,深入探讨了计算机是如何执行程序的。本篇博客将继续这一话题,聚焦于操作系统的核心概念之一——进程。进程是操作系统管理程序运行的基本单位,理解进程的概念有助于深入掌握操作系统的运行机制。
1. 什么是进程
进程是操作系统中最基本的执行单位。它指的是一个已经加载到内存并正在执行的程序实例。进程不仅仅是程序本身,还包括程序在运行过程中所需的各种资源,如CPU时间、内存空间、文件描述符等。
1.1 进程的定义与特性
从定义上来说,进程是一个正在执行的程序的实例。每个程序在运行时至少会生成一个进程,不论是用户启动的应用程序,还是操作系统后台运行的服务。进程具有以下几个显著特性:
- 动态性:程序是静态的文件,而进程是程序在系统中运行时的动态实体。操作系统管理进程的调度、暂停和终止,保证系统中多个进程能够并发执行。
- 独立性:每个进程都有独立的地址空间,进程之间无法直接访问彼此的内存。这样的独立性保证了进程的稳定运行,避免其他进程的错误或崩溃影响当前进程。
- 并发性:操作系统可以让多个进程“同时”运行,这种并发性是通过时间分片(时间片轮转)等调度策略实现的,实际上是在CPU快速切换执行不同进程。
1.2 进程与线程的区别
在理解进程的概念时,容易与线程混淆。进程和线程虽然都涉及程序的执行,但它们有显著的区别:
- 资源分配:进程是系统资源分配的基本单位,每个进程拥有独立的内存空间和系统资源。而线程是进程中的执行单元,多个线程共享同一个进程的资源。
- 调度单位:进程是操作系统调度的基本单位,系统通过调度进程来实现多任务处理。线程则是进程内部的调度单位,线程的调度发生在进程内部。
- 通信方式:由于进程之间拥有独立的地址空间,它们之间的通信通常需要通过复杂的机制如进程间通信(IPC),如管道、共享内存等。而线程共享进程的地址空间,线程之间的通信较为简单。
2.描述进程
在操作系统中,进程的信息被存储在一个数据结构(即PCB,进程控制块)中。这个数据结构包含了进程运行所需的所有关键信息,用以管理和调度进程。在Linux系统中,这个数据结构被称为task_struct
。通过task_struct
,内核能够全面掌握每个进程的状态、资源以及执行情况。
2.1 PCB (进程控制块)
进程控制块(Process Control Block,简称PCB)是操作系统用于描述和管理进程的关键数据结构。PCB包含了进程的所有属性,能够让操作系统跟踪和控制每一个进程的生命周期。在不同的操作系统中,PCB的实现略有不同。在Linux中,PCB以task_struct
结构体的形式存在。
PCB的作用可以理解为进程的属性集合,每个进程在创建时,系统都会生成对应的PCB。PCB中存储的进程信息包括:
- 进程ID(PID):用于唯一标识每个进程。
- 进程状态:当前进程的运行状态,例如运行中、阻塞中或等待中。
- 进程优先级:确定进程在调度中的优先顺序。
- 程序计数器:存储着进程下一条即将执行的指令地址。
- CPU寄存器:保存进程在暂停时的上下文,以便在重新调度时能够继续运行。
- 内存信息:包括进程的地址空间和所占用的内存块。
- I/O设备状态:与进程关联的输入输出设备信息。
2.2 task_struct
在Linux操作系统中,描述进程的核心数据结构是task_struct
。它是一种复杂的结构体,包含了与进程相关的所有信息。每个正在运行的进程在内存中都有一个task_struct
实例,操作系统通过它来跟踪和管理进程。
以下是task_struct
的结构体定义的一个简化版本,它展示了主要的进程信息字段:
struct task_struct {volatile long state; // 进程状态pid_t pid; // 进程IDpid_t tgid; // 线程组IDstruct mm_struct *mm; // 内存管理信息struct task_struct *parent; // 父进程struct list_head children; // 子进程链表unsigned int rt_priority; // 实时优先级unsigned int policy; // 调度策略struct files_struct *files; // 进程打开的文件struct fs_struct *fs; // 文件系统信息// 其他字段省略
};
task_struct
结构体中的字段可以大致分为以下几类:
-
标识符:每个进程都有唯一的进程标识符(PID)以及线程组ID(TGID)。这些标识符用于区分进程,并用于进程之间的操作。
-
状态:进程的状态由字段
state
表示。它记录了进程当前是处于运行、就绪、阻塞、终止等状态之一。此外,进程的退出代码和退出信号等信息也存储在相关字段中。 -
优先级:
rt_priority
用于表示实时进程的优先级,而policy
字段定义了进程的调度策略,如实时调度或普通调度。进程的优先级决定了它在调度中的优先程度。 -
程序计数器:进程即将执行的下一条指令的地址通过程序计数器保存,保证在进程调度时,能够从上次暂停的位置继续执行。
-
内存指针:
mm
字段指向内存管理结构体mm_struct
,该结构体包含了与进程相关的内存信息,如程序代码段、堆栈、数据段以及与其他进程共享的内存块。 -
上下文数据:
task_struct
中的寄存器上下文保存了进程暂停时的处理器寄存器内容,确保在进程恢复时能够继续之前的计算。 -
I/O状态信息:
files
字段保存了进程当前打开的文件列表,而fs
字段则包含了与进程相关的文件系统信息。这些字段提供了进程与I/O设备之间的交互信息。 -
记账信息:进程在运行期间的资源使用情况也会被记录,如使用的CPU时间、时钟周期等。系统可以根据这些信息对进程进行资源限制或计费。
task_struct
作为Linux内核中核心的进程描述结构体,通过合理的分类和管理,使得操作系统能够高效地管理进程的生命周期和资源分配。
3.查看进程
在Linux系统中,进程是系统运行的基本单位,操作系统为每个进程分配唯一的标识符和相关的资源。Linux提供了多种方式来查看系统中正在运行的进程信息,方便用户和系统管理员进行管理和调试。
3.1 查看进程信息
Linux系统提供了几种常用的命令和方法来查看进程信息。其中,/proc
虚拟文件系统是一个非常重要的机制,它动态地反映了系统中正在运行的进程和内核状态。除此之外,用户还可以使用一些常用命令,如ps
、top
、htop
等。
3.1.1 /proc
文件系统
/proc
目录是Linux中的一个虚拟文件系统,它实时地反映了系统中进程和内核的状态。每个正在运行的进程在/proc
目录下都有一个以其进程ID(PID)命名的子目录。在这些子目录中,可以查看与该进程相关的详细信息,如内存使用、打开的文件、状态等。
例如,查看进程ID为24533的进程状态,可以通过以下命令:
cat /proc/24533/status
该命令会显示进程的状态信息,包括PID、进程状态、内存使用、父进程ID等。/proc
文件系统是非常灵活且功能强大的工具,适用于查看特定进程的细节。
3.1.2 ps
命令
ps
命令是Linux中最常用的查看进程的命令之一。它能够显示当前系统中运行的进程列表及其相关信息。以下是几个常用的ps
命令用法:
ps -e
:列出系统中的所有进程。ps -aux
:详细列出所有进程的信息,包括用户、CPU和内存占用、进程ID等。ps -ef
:显示进程的完整格式,包括父进程和子进程的关系。
例如:
ps -aux
这条命令会输出系统中所有进程的详细信息,如进程ID、进程状态、用户、CPU占用率等。
3.1.2 top
和 htop
命令
top
是另一个非常有用的实时进程监控工具,它能够动态地显示系统中正在运行的进程,并按CPU、内存占用等进行排序。htop
是top
的增强版,提供了更友好的图形界面,用户可以更方便地查看和管理进程。
top
该命令会实时显示当前系统的进程和资源使用情况,用户可以根据CPU使用率、内存占用等来进行排序和管理。
3.2 获取进程标识符
在Linux系统中,进程标识符(PID)是每个进程的唯一标识,用来区分系统中的各个进程。可以通过多种方式获取进程的PID,包括使用命令和编写程序代码。
3.2.1使用命令获取PID
-
pidof
:获取特定程序的进程ID。例如,获取bash
进程的PID:pidof bash
该命令会返回
bash
进程的PID。 -
ps
:通过ps
命令结合grep
来查找特定进程的PID。例如:ps -aux | grep bash
这条命令会返回与
bash
相关的所有进程及其PID。
3.2.2 使用C语言程序获取PID
在C语言中,可以使用getpid()
系统调用获取当前进程的PID,同时可以使用getppid()
获取父进程的PID。以下是一个简单的C语言代码示例,展示如何获取并打印进程的PID和父进程的PID:
#include <stdio.h>
#include <unistd.h>int main() {pid_t pid, ppid;// 获取当前进程的PIDpid = getpid();// 获取父进程的PIDppid = getppid();// 打印PID和父进程的PIDprintf("当前进程的PID: %d\n", pid);printf("父进程的PID: %d\n", ppid);return 0;
}
编译并运行这段代码后,输出如下:
通过这段代码,可以轻松获取并打印进程的唯一标识符和父进程的标识符。在Linux编程中,了解进程的PID是进行进程间通信、管理进程生命周期的重要步骤。
4. 通过系统调用创建进程
在Linux操作系统中,进程的创建通常是通过系统调用来完成的。系统调用提供了程序与内核交互的接口,fork()
是最常用的创建进程的系统调用之一。
4.1 认识 fork
fork()
系统调用用于创建一个新进程,称为子进程。调用fork()
时,系统会复制当前进程,生成一个几乎完全相同的子进程。子进程继承了父进程的所有资源(如文件描述符、内存映射等),但它有自己独立的进程ID(PID)。
-
父进程与子进程的区别:
fork()
的返回值在父进程和子进程中不同。在父进程中,fork()
返回子进程的PID;在子进程中,fork()
返回0。这使得父进程和子进程可以根据返回值执行不同的代码。 -
多进程并发:通过
fork()
创建子进程后,父子进程会并发执行。操作系统通过调度来分配CPU时间片,确保多个进程能够同时运行。
4.2 代码实践
以下是一个简单的C语言示例,通过fork()
创建子进程,并在父子进程中分别输出不同的信息:
#include <stdio.h>
#include <unistd.h>int main() {pid_t pid;// 调用fork创建新进程pid = fork();if (pid < 0) {// fork失败fprintf(stderr, "fork 失败\n");return 1;} else if (pid == 0) {// 子进程执行printf("这是子进程,进程ID: %d\n", getpid());} else {// 父进程执行printf("这是父进程,进程ID: %d,子进程ID: %d\n", getpid(), pid);}return 0;
}
输出示例:
在这个程序中,调用fork()
后会创建一个新的子进程,父进程和子进程根据fork()
的返回值分别执行不同的代码。父进程打印自己的进程ID和子进程的ID,而子进程只打印自己的ID。
5.小结
进程是操作系统中最重要的概念之一,理解它的基本概念和工作原理有助于更深入地掌握操作系统的运行机制。在Linux中,进程通过PCB
和task_struct
结构体来描述,进程的创建可以通过fork
系统调用来实现。在后续的博客中,我们将继续探讨进程的调度和通信机制。
相关文章:

Linux 进程的基本概念及描述
目录 0.前言 1. 什么是进程 1.1 进程的定义与特性 1.2 进程与线程的区别 2.描述进程 2.1 PCB (进程控制块) 2.2 task_struct 3.查看进程 3.1 查看进程信息 3.1.1 /proc 文件系统 3.1.2 ps 命令 3.1.2 top 和 htop 命令 3.2 获取进程标识符 3.2.1使用命令获取PID 3.2.2 使用C语言…...

【C++】透过STL源代码深度剖析vector的底层
✨ Blog’s 主页: 白乐天_ξ( ✿>◡❛) 🌈 个人Motto:他强任他强,清风拂山冈! 🔥 所属专栏:C深入学习笔记 💫 欢迎来到我的学习笔记! 参考博客:【C】透过STL源…...

ubuntu 开启root
sudo passwd root#输入以下命令来给root账户设置密码 sudo passwd -u root#启用root账户 su - root#要登录root账户 root 开启远程访问: 小心不要改到这里了:sudo nano /etc/ssh/ssh_config 而是:/etc/ssh/sshd_config sudo nano /etc/ssh…...

使用 Llama 3.1 和 Qdrant 构建多语言医疗保健聊天机器人的步骤
长话短说: 准备好深入研究: 矢量存储的复杂性以及如何利用 Qdrant 进行高效数据摄取。掌握 Qdrant 中的集合管理以获得最佳性能。释放上下文感知响应的相似性搜索的潜力。精心设计复杂的 LangChain 工作流程以增强聊天机器人的功能。将革命性的 Llama …...

【Linux-基础IO】如何理解Linux下一切皆文件磁盘的介绍
目录 如何理解Linux系统上一切皆文件 1.物理角度认识磁盘 2.对磁盘的存储进行逻辑抽象 磁盘寻址 3.磁盘中的寄存器 如何理解Linux系统上一切皆文件 计算机中包含大量外设,操作系统想要管理好这些外设,就必须对这些外设进行先描述再组织,…...

Golang | Leetcode Golang题解之第436题寻找右区间
题目: 题解: func findRightInterval(intervals [][]int) []int {n : len(intervals)type pair struct{ x, i int }starts : make([]pair, n)ends : make([]pair, n)for i, p : range intervals {starts[i] pair{p[0], i}ends[i] pair{p[1], i}}sort.…...

微服务SpringSession解析部署使用全流程
目录 1、SpringSession简介 2、实现session共享的三种方式 1、修改Tomcat配置文件 2、Nginx负载均衡策略 3、redis统一存储 0、准备工作 1、本地服务添加依赖 2、修改本地服务配置文件 3、添加application.properties文件 4、添加nacos - redis配置 5、修改本地项目…...
自动驾驶 3DGS 学习笔记
目录 street_gaussians gsplat依赖项 运行报错: python>3.9 SGD: Street View Synthesis with Gaussian Splatting and Diffusion Prior 差分高斯光栅化 diff-gaussian-rasterization street_gaussians https://github.com/zju3dv/street_gaussians gsp…...

【C++笔试强训】如何成为算法糕手Day5
学习编程就得循环渐进,扎实基础,勿在浮沙筑高台 循环渐进Forward-CSDN博客 目录 循环渐进Forward-CSDN博客 第一题:游游的you 思路: 第二题:腐烂的苹果 思路: 第三题:孩子们的游戏 思路&…...
【Qt】无IDE的Gui程序快速开始
Qt安装 在 Windows 上安装 Qt 的步骤如下: 下载 Qt 安装程序 访问 Qt 的官方网站:Qt Downloads。点击“Download”按钮,下载 Qt Online Installer(在线安装程序)。 运行安装程序 双击下载的 QtInstaller.exe 文件…...

Python编码系列—Python备忘录模式:掌握对象状态保存与恢复技术
🌟🌟 欢迎来到我的技术小筑,一个专为技术探索者打造的交流空间。在这里,我们不仅分享代码的智慧,还探讨技术的深度与广度。无论您是资深开发者还是技术新手,这里都有一片属于您的天空。让我们在知识的海洋中…...
linux常用命令汇编(持续更新)
一、用户提示符 # root账号提示符 $ 普通用户提示符 二、关闭计算机 shutdown(安全有序地关闭计算机) 语法:shutdown [options] [time] [message] shutdown -h now #立即关机(--halt/终止) shutdown -r now #重…...

AI面试指南:AI工具总结评测,助力求职季
AI面试指南:AI工具总结评测,助力求职季 摘要: 在竞争激烈的AI领域秋招季,准备充分并借助高效工具是提升面试通过率的关键。本文主要介绍一些针对秋招的AI面试工具和学习资源,分为简历优化、面试助手、手撕代码练习三个…...
大二考核题解
大二考核题解 题号题目考察知识点A有意思的监考二分答案B海绵宝宝的数独DFSC走楼梯递推D碱基配对kmpE好简单的题啊,写它!最短路 写在前面: 整体难度不大,代码能力需要一些,正常来说至少要会3题以上 A 有意思的监考 …...
深入解析:Kubernetes 如何使用 etcd 作为配置中心和注册中心
在 Kubernetes 中,etcd 是核心的分布式存储组件,负责存储和管理集群的所有配置信息、状态数据以及服务注册信息。etcd 的高可用性和强一致性使得它成为 Kubernetes 的 “source of truth”,确保集群能够动态、高效地管理资源,并保…...

MQ高级:RabbitMQ小细节
在之前的学习中,我们只介绍了消息的发送,但是没有考虑到异常的情况,今天我们就介绍一些异常情况,和细节的部分。 目录 生产者可靠性 生产者重连 生产者确认 MQ可靠性 持久化 Lazy Queue 消费者可靠性 消费者确认机制 失…...

期权卖方怎么选择权利金高的品种,期货VIX高低对行情有什么影响
VIX指数——全称为芝加哥期权交易所市场波动率指数,俗称恐慌指数。 是衡量波动性的重要指标。VIX指数上升,预期未来市场波动性会增加。VIX指数下降,预期未来市场波动性会降低。 期货VIX指数最新价格排序 期权卖方尽量选择期货VIX指数在25以…...
内存对齐的原理和使用
1. 什么是内存对齐? 内存对齐是指将数据存储在内存中时,按照数据类型的大小,将数据放在特定的内存边界上。例如,4 字节的 int 通常放在能够被 4 整除的地址上,8 字节的 double 则放在能被 8 整除的地址上。 2. 为什么…...

搭建企业级私有仓库harbor
华子目录 harbor简介实验环境准备下载软件包安装docker-cehosts解析 实验步骤配置https加密传输解压进入解压目录,修改文件配置启动harbor 测试客户端配置harbor本地加速器注意 通过docker compose管理harbor harbor简介 harbor是由wmware公司开源的企业级docker r…...
互联网前后端分离的开发场景,一般会员和数据权限的判断是放在前端还是后端?
推荐学习文档 golang应用级os框架,欢迎stargolang应用级os框架使用案例,欢迎star案例:基于golang开发的一款超有个性的旅游计划app经历golang实战大纲golang优秀开发常用开源库汇总想学习更多golang知识,这里有免费的golang学习笔…...

通过Wrangler CLI在worker中创建数据库和表
官方使用文档:Getting started Cloudflare D1 docs 创建数据库 在命令行中执行完成之后,会在本地和远程创建数据库: npx wranglerlatest d1 create prod-d1-tutorial 在cf中就可以看到数据库: 现在,您的Cloudfla…...

(二)原型模式
原型的功能是将一个已经存在的对象作为源目标,其余对象都是通过这个源目标创建。发挥复制的作用就是原型模式的核心思想。 一、源型模式的定义 原型模式是指第二次创建对象可以通过复制已经存在的原型对象来实现,忽略对象创建过程中的其它细节。 📌 核心特点: 避免重复初…...
第25节 Node.js 断言测试
Node.js的assert模块主要用于编写程序的单元测试时使用,通过断言可以提早发现和排查出错误。 稳定性: 5 - 锁定 这个模块可用于应用的单元测试,通过 require(assert) 可以使用这个模块。 assert.fail(actual, expected, message, operator) 使用参数…...

UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)
UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中,UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化…...

【JavaWeb】Docker项目部署
引言 之前学习了Linux操作系统的常见命令,在Linux上安装软件,以及如何在Linux上部署一个单体项目,大多数同学都会有相同的感受,那就是麻烦。 核心体现在三点: 命令太多了,记不住 软件安装包名字复杂&…...
Swagger和OpenApi的前世今生
Swagger与OpenAPI的关系演进是API标准化进程中的重要篇章,二者共同塑造了现代RESTful API的开发范式。 本期就扒一扒其技术演进的关键节点与核心逻辑: 🔄 一、起源与初创期:Swagger的诞生(2010-2014) 核心…...

2025季度云服务器排行榜
在全球云服务器市场,各厂商的排名和地位并非一成不变,而是由其独特的优势、战略布局和市场适应性共同决定的。以下是根据2025年市场趋势,对主要云服务器厂商在排行榜中占据重要位置的原因和优势进行深度分析: 一、全球“三巨头”…...

Selenium常用函数介绍
目录 一,元素定位 1.1 cssSeector 1.2 xpath 二,操作测试对象 三,窗口 3.1 案例 3.2 窗口切换 3.3 窗口大小 3.4 屏幕截图 3.5 关闭窗口 四,弹窗 五,等待 六,导航 七,文件上传 …...

【Linux】Linux 系统默认的目录及作用说明
博主介绍:✌全网粉丝23W,CSDN博客专家、Java领域优质创作者,掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域✌ 技术范围:SpringBoot、SpringCloud、Vue、SSM、HTML、Nodejs、Python、MySQL、PostgreSQL、大数据、物…...

R 语言科研绘图第 55 期 --- 网络图-聚类
在发表科研论文的过程中,科研绘图是必不可少的,一张好看的图形会是文章很大的加分项。 为了便于使用,本系列文章介绍的所有绘图都已收录到了 sciRplot 项目中,获取方式: R 语言科研绘图模板 --- sciRplothttps://mp.…...