当前位置: 首页 > news >正文

【linux 多进程并发】linux进程状态与生命周期各阶段转换,进程状态查看分析,助力高性能优化

0102 Linux进程生命周期

专栏内容

  • postgresql使用入门基础
  • 手写数据库toadb
  • 并发编程

个人主页:我的主页
管理社区:开源数据库
座右铭:天行健,君子以自强不息;地势坤,君子以厚德载物.

文章目录

  • 0102 Linux进程生命周期
  • 一、概述
  • 二、进程状态
  • 三、进程的生命周期
    • 3.1 周期阶段
    • 3.2 状态查看
  • 四、总结
  • 结尾

一、概述


在多任务并发编程中,进程是一个非常重要的概念,在应用程序运行时,都是以进程的方式启动,再展开为多进程或多线程的架构。

涉及到系统编程,每个操作系统平台实现存在差异,这里以linux操作系统为例。

在Linux操作系统中,进程是程序的一个实例化(也就是运行起来后),是系统进行资源分配和调度的基本单位。

每个进程是独立的占有资源,会被分配独立的内存空间,CPU核,文件描述符等。

进程之间通过进程间通信(IPC)机制进行通信和同步,当然这里是与线程有区别。

多进程编程就是在同一程序中创建并运行多个进程,以实现并发处理。

本节就来总体介绍一下linux下的进程相关知识,后续会对每个点进行详细介绍。
在这里插入图片描述

二、进程状态


在这里插入图片描述

在这此状态中有三个基本状态:

  • 就绪,进程的资源准备好了,尚未被分配CPU,此时处在就绪等待的状态;
  • 运行,进程被分配了CPU时间片,在分配的CPU核上正在执行时的状态;
  • 阻塞,或者睡眠;此时进程需要的资源尚未满足时所处的状态,此时会放弃占用的CPU;

三个状态相互转换:

  • 当就绪的进程被分配到CPU时,就会转换为运行状态;
  • 当运行状态的进程CPU时间片用完时,就会转换为就绪状态,等待再次分配CPU;
  • 当运行状态的进程中调用sleep或者read/write磁盘文件时,就会进入阻塞状态;
  • 当阻塞状态的进程,达到唤醒条件时,比如定时器超时,或者磁盘数据加载到了缓存时,就会转换为就绪状态;

三、进程的生命周期


在进程启动之后,通过一系列状态标识进程当前所处的阶段,直至进程结束。

3.1 周期阶段

在这里插入图片描述

对基本状态再进行细化后,整个进程的生命周期状态分为以下几种:

  • 创建:进程被创建,但尚未准备好执行。
  • 就绪:进程已准备好执行,但尚未被分配CPU时间。
  • 运行:进程正在执行。
  • 可中断的阻塞:进程在等待管道,锁等,当收到信号时可以被中断;
  • 不可中断的阻塞:进程正在等待IO动作完成,不能被信号中断;
  • 终止(Terminated):进程已完成执行或被终止。

3.2 状态查看

前一章节介绍了进程的查看方法,查看实时的活动状态,我们使用top命令;

执行命令之后,进程当前的状态是S列的值,状态取值有以下几种:

 S  --  Process Status
The status of the task which can be one of:D = uninterruptible sleepI = idleR = runningS = sleepingT = stopped by job control signalt = stopped by debugger during traceZ = zombie
  • D,对应于不可中断的阻塞;
  • I,正在处于就绪空闲状态;
  • R,正在运行当中;
  • S,对应于可中断的阻塞;
  • T,被任务控制信号停止
  • t, 当前进程处理调试当前;
  • Z,也就是僵尸进程;

下面我们来看看实际运行的情况,在终端执行top命令:

top - 09:04:55 up 436 days, 58 min, 19 users,  load average: 3.65, 3.84, 3.86
Threads: 1512 total,   5 running, 1502 sleeping,   3 stopped,   2 zombie
%Cpu(s):  7.0 us, 13.6 sy,  0.2 ni, 77.3 id,  0.0 wa,  0.1 hi,  1.8 si,  0.0 st
MiB Mem :  31672.7 total,    260.3 free,  12496.5 used,  18915.9 buff/cache
MiB Swap:   1020.0 total,      0.0 free,   1020.0 used.  16843.8 avail MemPID USER      PR  NI    VIRT    RES    SHR S  %CPU  %MEM     TIME+ COMMAND
1463957 senllang  20   0 2071732   1.2g   1644 R  75.6   3.7  25023:00 ./toadb-0-01 -M 2
1463958 senllang  20   0 2071732   1.2g   1644 R  75.6   3.7  25068:32 ./toadb-0-01 -M 2
1463959 senllang  20   0 2071732   1.2g   1644 S   1.3   3.7  25609:34 ./toadb-0-01 -M 2
3125409 root      20   0       0      0      0 D   1.0   0.0   0:01.80 [kworker/u32:0+flush-8:0]

可以看到有R,S,D几种状态。

当需要关注程序的性能时,如果处理D时间较长,就需要优化缓存等。

四、总结


本文介绍了linux平台下进程的基本状态,这些状态经过细化后对应进程生命周期中的各阶段;进程从创建启动之后,就处于一个有限状态机中,从就绪,运行,可中断阻塞,不可中断阻塞之间进行转换,直到进程的终止。

结尾


非常感谢大家的支持,在浏览的同时别忘了留下您宝贵的评论,如果觉得值得鼓励,请点赞,收藏,我会更加努力!

作者邮箱:study@senllang.onaliyun.com
如有错误或者疏漏欢迎指出,互相学习。

注:未经同意,不得转载!

相关文章:

  • 51单片机和ARM单片机的区别
  • “领航猿1号” 正式更名为 “AGI舰长”
  • 代码随想录冲冲冲 Day59 图论Part10
  • 数据结构 ——— C语言实现无哨兵位单向不循环链表
  • Linux基础命令lsblk详解
  • vue限定类型上传文件 最简单实践(单个可文件、可图片)
  • Hive数仓操作(五)
  • STM32--GPIO点亮LED灯(手把手,超详细)
  • @antv/x6 动态的修改attr与prop,以及动态改变节点的大小
  • 2024年_ChatGPT 及类似的人工智能技术带来的影响与改变 怎样利用 ChatGPT 提高学习效率
  • 【JAVA源码授权】
  • 计算机毕业设计Hadoop+Spark知识图谱美团美食推荐系统 美团餐厅推荐系统 美团推荐系统 美食价格预测 美团爬虫 美食数据分析 美食可视化大屏
  • ​IAR全面支持国科环宇AS32X系列RISC-V车规MCU
  • Spring Boot CLI命令行工具
  • Java中的PriorityQueue详解
  • 深入了解以太坊
  • 07.Android之多媒体问题
  • ABAP的include关键字,Java的import, C的include和C4C ABSL 的import比较
  • Eureka 2.0 开源流产,真的对你影响很大吗?
  • js如何打印object对象
  • mysql常用命令汇总
  • pdf文件如何在线转换为jpg图片
  • underscore源码剖析之整体架构
  • Windows Containers 大冒险: 容器网络
  • XML已死 ?
  • yii2权限控制rbac之rule详细讲解
  • 构建二叉树进行数值数组的去重及优化
  • 模仿 Go Sort 排序接口实现的自定义排序
  • 用简单代码看卷积组块发展
  • 源码之下无秘密 ── 做最好的 Netty 源码分析教程
  • mysql面试题分组并合并列
  • 从如何停掉 Promise 链说起
  • ​Redis 实现计数器和限速器的
  • ​secrets --- 生成管理密码的安全随机数​
  • ​如何使用QGIS制作三维建筑
  • !!【OpenCV学习】计算两幅图像的重叠区域
  • !!Dom4j 学习笔记
  • # linux从入门到精通(三)
  • #Datawhale X 李宏毅苹果书 AI夏令营#3.13.2局部极小值与鞍点批量和动量
  • #if #elif #endif
  • #pragma 指令
  • #每天一道面试题# 什么是MySQL的回表查询
  • (层次遍历)104. 二叉树的最大深度
  • (附源码)计算机毕业设计SSM智慧停车系统
  • (心得)获取一个数二进制序列中所有的偶数位和奇数位, 分别输出二进制序列。
  • .NET/C# 如何获取当前进程的 CPU 和内存占用?如何获取全局 CPU 和内存占用?
  • .Net各种迷惑命名解释
  • .NET与 java通用的3DES加密解密方法
  • .net之微信企业号开发(一) 所使用的环境与工具以及准备工作
  • //TODO 注释的作用
  • @Autowired和@Resource的区别
  • @Autowired注解的实现原理
  • @RequestMapping-占位符映射
  • @vue/cli 3.x+引入jQuery
  • [ C++ ] 类和对象( 下 )