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学习笔…...
李宏毅机器学习2022-HW8-Anomaly Detection
文章目录 TaskBaselineReportQuestion2 Code Link Task 异常检测Anomaly Detection 将data经过Encoder,在经过Decoder,根据输入和输出的差距来判断异常图像。training data是100000张人脸照片,testing data有大约10000张跟training data相同…...
用户体验分享 | YashanDB V23.2.3安装部署
近期崖山新版体验过程中,总能看到用户提问:openssl版本问题、monit命令找不到问题、yashan用户权限问题、数据库重装问题 今日整理了多位用户的安装经验,希望能够帮助到大家~ 1.Lucifer三思而后行 :YashanDB 个人版数据库安装部…...
【漏洞复现】泛微OA E-Office /E-mobile/App/init.php 任意文件上传漏洞
免责声明: 本文旨在提供有关特定漏洞的信息,以帮助用户了解潜在风险。发布此信息旨在促进网络安全意识和技术进步,并非出于恶意。读者应理解,利用本文提到的漏洞或进行相关测试可能违反法律或服务协议。未经授权访问系统、网络或应用程序可能导致法律责任或严重后果…...
SpringCloudEureka实战:搭建EurekaServer
1、依赖引入 <dependencies><!-- 注册中心 --><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-eureka-server</artifactId></dependency> </dependencies> <de…...
DataLight(V1.4.5) 版本更新,新增 Ranger、Solr
DataLight(V1.4.5) 版本更新,新增 Ranger、Solr DataLight 迎来了重大的版本更新,现已发布 V1.4.5 版本。本次更新对平台进行了较多的功能拓展和优化,新增了对 Ranger 和 Solr 服务组件的支持,同时对多项已…...
深度解析:Python蓝桥杯青少组精英赛道与高端题型概览
目录 一、蓝桥杯青少组简介二、赛项组别与年龄范围三、比赛内容与题型1. 基础知识范围2. 题型设置2.1 选择题2.2 编程题 3. 考试时长 四、奖项设置与激励措施五、总结 一、蓝桥杯青少组简介 蓝桥杯全国软件和信息技术专业人才大赛(简称“蓝桥杯”)是由工…...
如何使用SCCMSecrets识别SCCM策略中潜在的安全问题
关于SCCMSecrets SCCMSecrets是一款针对SCCM策略的安全扫描与检测工具,该工具旨在提供一种有关 SCCM 策略的全面安全检测方法。 该工具可以从各种权限级别执行,并将尝试发现与策略分发相关的潜在错误配置。除了分发点上托管的包脚本外,它还将…...
Qt 信号重载问题--使用lambda表达式--解决方法
在connect()中,使用lambda表达式时遇到信号重载,无法识别使用哪个参数时,可通过以下方法处理: 1. 使用QOverload: Qt5.7才有 connect(comboBox,QOverload<int>::of(&QComboBox::currentIndexChanged), [](int index)…...
并行编程实战——TBB框架的应用之一Supra的基础
一、TBB的应用 在前面分析了TBB框架的各种基本知识和相关的基础应用。这些基础的应用很容易通过学习文档或相关的代码来较为轻松的掌握。为了能够更好的理解TBB框架的优势,这里从一个开源的应用程序来分析一下TBB在其中的更高一层的抽象应用,以方便开发…...
std::vector
std::vector是C标准库中一个非常强大的容器类,它提供了动态数组的功能。std::vector可以自动调整大小,提供了随机访问的能力,同时还支持在序列的尾部高效地添加和删除元素。 当创建一个空的std::vector对象时,它不分配任何内存&a…...
wordpress的分类目录做成树/seo培训教程
文章目录一、题目1、题目描述2、基础框架3、原题链接二、解题报告1、思路分析2、时间复杂度3、代码详解三、本题小知识四、加群须知一、题目 1、题目描述 给你一个字符串数组 words,找出并返回数组中的第一个回文字符串 。如果不存在满足要求的字符串,返…...
做网站能挣多少钱/下载百度官方版
大家好,要么做连锁、要么被连锁,我是连锁大亨。要么做连锁,要么被连锁,大家好,我是连锁大亨。哈佛商学院:“连锁,是21世纪最好的商业模式!”我们会发现这并不是一个新新世界…...
http网站跳转怎么做/专业网络推广公司
PDC(专业开发人员会议)一直是由微软的高级开发者和架构师作为参与者,以便了解未来的微软平台和技术,PDC 2010,您将可以获得关于微软下一代云服务、Windows Phone 7、工具和技术、Internet Explorer 9 和游戏平台的第一手内容,PDC …...
wordpress 微信付款/百度手机助手下载安装
点击下载Qt6最新试用版 COM应用程序的例子展示了如何使用ActiveQt来开发一个可以通过COM自动化的Qt应用程序。不同的基于QObject的类被暴露为COM对象,与运行中的Qt应用程序的GUI进行通信。这些COM对象的API被设计成类似于标准COM应用程序的API,即那些来…...
wordpress中文免费/广东企业网站seo报价
第1章 Sed替换与别名设置1.1 cp复制与覆盖已知/tmp下已经存在test.txt文件,如何执行命令才能把/mnt/test.txt拷贝到/tmp下覆盖掉/tmp/test.txt,而让系统不提示是否覆盖(root权限下)。 [rootoldboyedu50 ~]# cp /mnt/test.txt /tmp…...
自己建网站用gbk/东莞专业网站推广工具
本来是一件很简单的事情。cvsup -gL 2 -h cvsup.freebsd.org /usr/share/examples/cvsup/ports-supfilecd /usr/ports/lang/php5(或者用:/usr/ports/www/mod_php5)make install clean但是结果却发现pivot无法运行,报一个错误,说是什么函数找不…...