【Linux】进程轻松入门

目录

一, 冯* 诺依曼体系结构

1,存储结构

​编辑

二, 操作系统 

1,概念

2,设计OS的目的

3,定位

4,如何理解 "管理"

5, 总结 

三,进程

1. 概念

 那么如何区分进程  & 程序?

2. PCB —— 描述进程

3. 组织进程

补充: cwd

 4.  task_struct ——PCB

 (1) PID——标识符

5.父子进程 

补充: fork()函数

fork函数——if分流

父子进程——各自优先级

6. 进程状态【Linux操作系统】

1. 新建:

2. 运行状态:

3. 阻塞:

4. 挂起:

6. liunx内核中的进程状态 

(1) S睡眠状态(sleeping):

 (2) R运行状态(running):

(3) D磁盘休眠状态(Disk sleep):

(4) T停止状态(stopped):

T 区别于 S:

(5) X死亡状态(dead):

(6) Z僵尸状态:

僵尸进程的危害

(7) 孤儿进程

 7. 进程优先级

修改优先级


 

 

一, 冯* 诺依曼体系结构

1,存储结构

         我们知道一个程序的执行速度,需要数据的输入输出。那么如果CPU直接与输入设备进行交互,那么会是这样的情况,输入设备输入10s的数据,CPU处理花了1ms,然后输出又花了10s,这样会导致机器性能很差;

而冯洛依曼想到了用内存与CPU打交道,这样就变成了4秒的数据输入,1ms的处理,4秒的输出变相的提高了计算机效率

 

举一个例子:我与一个老表进行微信交流。他们之间的数据流动流程图,如下:

二, 操作系统 

1,概念

任何计算机系统都包含一个基本的程序集合,称为操作系统(OS)。笼统的理解,操作系统包括:
内核(进程管理,内存管理,文件管理,驱动管理)
其他程序(例如函数库,shell程序等等)

2,设计OS的目的

与硬件交互,管理所有的软硬件资源
为用户程序(应用程序)提供一个良好的执行环境

3,定位

在整个计算机软硬件架构中,操作系统的定位是: 一款纯正的“搞管理”的软件

4,如何理解 "管理"

管理步骤:
(1.) 描述被管理对象
(2.) 组织被管理对象

关于操作系统,银行例子:

5, 总结 

  操作系统就是给用户提供一个安全,稳定,简单的执行环境

1. 操作系统管理:先描述,再组织

2. 操作系统对外服务,是通过提供:系统调用接口 

三,进程

1. 概念

课本概念:程序的一个执行实例,正在执行的程序等
内核观点:担当分配系统资源(CPU时间,内存)的实体。

(其实,我们启动一个软件,本质上是创建一个进程; 并且在linux中输入一个命令,在系统层面创建了一个进程)  

 那么如何区分进程  & 程序?

问: 一个系统中能存在大量进程吗? 答案是:可以的 ;

当大量进程进入内存,CPU需要对进程优先级进行排序,而它做不到 ,它只能读数据,那么这个时候就需要对进程进行管理,那么我们如何创建进程?

1. 先描述   (通过结构体(PCB),描述进程属性块)
2. 再组织     (通过数据结构,如链表,顺序表,红黑树等,将进程组织起来)

那么我们开始来管理进程:

2. PCB —— 描述进程

         进程信息被放在一个叫做进程控制块的数据结构中,可以理解为进程属性的集合。课本上称之为PCB(process control block),Linux操作系统下的PCB是: task_struct

在windows中,PCB就是一个表示进程模块的结构体

在Linux中,PCB的具体是 struct  task_struct{......// 进程的所有属性}

task_struct 是 PCB的一种 ,在Linux中描述进程的结构体叫做task_struct。task_struct是Linux内核的一种数据结构,它会被装载到RAM(内存)里并且包含着进程的信息。

3. 组织进程

可以在内核源代码里找到它。所有运行在系统里的进程都以task_struct链表的形式存在内核里。 

那我们如何查看一个进程? 

(1). 我们制作一个死循环程序,然后执行程序。

 

(2)再打开另一个窗口查看进程。

指令:ps  axj  |  grep  "需要查看的程序" 

 回到死循环程序,我们通过ctrl +  c退出死循环程序,再次检测可以发现,死循环进程消失。

同样的我们可以通过输入top命令,而这就是Linux下的任务管理器 

补充: cwd

输入   ls   /proc    // 功能是:通过文件形式来展示进程

 我们随便进入一个进程,查看里面文件属性,这里就有我们要找的cwd文件:

 转成详细页:ls /proc/13712     // 13712是Test进程的PID

那这些PPID,PID是什么玩意儿,下面我们会进行分析。

 4.  task_struct ——PCB

 前面我们可以看到有这些类

  • 标示符 (PID):  描述本进程的唯一标示符,用来区别其他进程
  • 状态:  任务状态,退出代码,退出信号等。
  • 优先级:  相对于其他进程的优先级。(权限决定能与不能,优先级是能后的顺序)
  • 程序计数器:  程序中即将被执行的下一条指令的地址。(所以程序计数器是不断被修改的)
  • 内存指针:  包括程序代码和进程相关数据的指针,还有和其他进程共享的内存块的指针。(可以通过PCB找到进程中的数据
  • 上下文数据:   进程执行时处理器的寄存器中的数据。   [休学例子,要加图CPU,寄存器]
  • IO状态信息: 包括显示的I/O请求,分配给进程的IO设备和被进程使用的文件列表。
  • 记账信息: 可能包括处理器时间总和,使用的时钟数总和,时间限制,记账号等。
  • 其他信息

 (1) PID——标识符

功能: 标示符 (PID):  描述本进程的唯一标示符,用来区别其他进程

 那么我们怎么在main函数获取特定的进程的PID呢?

getpid()  // 获取本进程PID

getppid()   // 获取父进程PID

 需要包含系统函数头文件: #include <sys/types.h>  

我们在源码中,运用getpid()函数,获取本程序的PID 

结果如图:

这里除了 在程序运行时ctrl + c可以终止进程;也可以通过 输入命令  kill -9  PID  结束进程。 这里不对kill进行讲解。

5.父子进程 

补充: fork()函数

功能:在fork函数调用处,创建一个子进程独立于父进程,fork之后代码父子共享

返回值:1. 在父进程中返回子进程的PID; 2. 在子进程返回 0 ;  3. 失败返回 -1

问:为啥会有两个返回值呢?

答:fork()函数中,父子进程各自执行自己的return语句

 

fork函数——if分流

 我们知道父子进程公用,fork函数之后的代码。可父子进程大多都是运行不同的代码,那我们如何进行分开呢?

利用fork的返回值进行if  分流:

id 在父进程里面是 子进程的PID; 在子进程里面是 0 。

关于fork函数内部逻辑:

创建一个进程,内部属性以父进程内部属性为模板。

父子进程——各自优先级

问: 父子进程中,先执行父进程,再执行子进程吗?

不一定

原因:CPU可能运行一个父进程10ms后,先不执行了,再次入运行队列,而这时子进程就在执行。关于谁先运行,不一定,这个取决于操作系统的调度器决定

6. 进程状态【Linux操作系统】

1. 新建

字面意思。 就是给一个程序创建有一个进程。

2. 运行状态

task_struct在运行队列中开始排队时,就是运行状态。

3. 阻塞

等待非CPU资源,叫做阻塞状态。

比如:我们进行scanf / cin 进行键盘输入时,在等待键盘数据录入,这就是一个阻塞状态。

4. 挂起

当内存不足时,OS适当地置换进程的代码和数据到磁盘,此时进程叫做挂起状态。

6. liunx内核中的进程状态 

为了弄明白正在运行的进程是什么意思,我们需要知道进程的不同状态。一个进程可以有几个状态(在Linux内核里,进程有时候也叫做任务。)

(1) S睡眠状态(sleeping):

意味着进程在等待事件完成  (这里的睡眠有时候也叫做可中断睡眠——可以通过kill -2 指令,中断S,为T状态

对应阻塞状态 

输入: while :; do  ps   axj |  head -1 && ps axj  | grep  运行文件名  |  grep -v grep ;  sleep 1;  done    // 可查看最新的进程运行状况,周期为1秒

 (2) R运行状态(running):

并不意味着进程一定在运行中,它表明进程要么是在运行中要么在运行队列里。

 以上面代码为例,将cout代码注释掉,这样就不在占用输出设备资源了,则一直都在R状态。

 细节:我们发现状态栏中有S+,R+ 其中"+"又是什么意思呢?     “+”这里的含义是一个前台进程,其结果会占用我们与bush的聊天界面,我们无法输入指令,可以ctrl +  c 退出;同理,没有“+”的状态为后台进程,不会占用聊天框,我们可以继续输入指令。 但启动程序时要 ./程序    &,它会返回其PID,不用时kill -9  PID 杀死即可。

(3) D磁盘休眠状态(Disk sleep):

有时候也叫不可中断睡眠状态(uninterruptible sleep)——深度睡眠,在这个状态的进程通常会等待IO的结束。(不可被被动中断,kill都不能杀掉,除非拔电源

(4) T停止状态(stopped):

可以通过发送 SIGSTOP 信号给进程来停止(T)进程。这个被暂停的进程可以通过发送 SIGCONT 信号让进程继续运行。(比如:gdb调试

 

kill -19   // 暂停进程

kill -18   // 继续进程

T 区别于 S:

 睡眠进程是等待非CPU资源, 对应的是阻塞状态。暂停状态,原先是运行状态,没有等待资源,仅仅是暂停了。

(5) X死亡状态(dead):

这个状态只是一个返回状态,你不会在任务列表里看到这个状态.(当大量进程结束时,操作系统忙不过来,那这时进程就会标记为X进程,随时准备被回收)

(6) Z僵尸状态:

一个进程已经退出,但还不能被OS回收,处于一个等待被检测的状态,叫做僵尸状态。

那为啥要有这种状态?  为了状态保持,让父进程或者OS来检测。 (所谓的保持:指代码和数据被回收了,进程的PCB还保留着。

僵尸进程的危害

  1. 进程的退出状态必须被维持下去,因为他要告诉关心它的进程(父进程),你交给我的任务,我办的怎么样了。可父进程如果一直不读取,那子进程就一直处于Z状态?是的!
  2. 维护退出状态本身就是要用数据维护,也属于进程基本信息,所以保存在task_struct(PCB)中,换句话说,Z状态一直不退出,PCB一直都要维护?是的!
  3. 那一个父进程创建了很多子进程,就是不回收,是不是就会造成内存资源的浪费?是的!   因为数据结构对象本身就要占用内存,想想C中定义一个结构体变量(对象),是要在内存的某个位置进行开辟空间!
  4. 内存泄漏?是的

 

(7) 孤儿进程

概念:

父进程如果提前退出,那么子进程后退出,进入Z之后,那该如何处理呢? 父进程先退出,子进程就称之为“孤儿进程”孤儿进程被1号init进程领养,当然要有init进程回收喽

我们简单创建一个父进程先退出,子进程后退出的场景。发现:

 

 

 7. 进程优先级

 概念:

cpu资源分配的先后顺序,就是指进程的优先权(priority)。优先权高的进程有优先执行权利。配置进程优先权对多任务环境的linux很有用,可以改善系统性能。
还可以把进程运行到指定的CPU上,这样一来,把不重要的进程安排到某个CPU,可以大大改善系统整体性能。

查看优先级,输入:

ps   -al     // 会显示机器所以进程 

我们很容易注意到其中的几个重要信息,有下:
UID : 代表执行者的身份
PID : 代表这个进程的代号
PPID :代表这个进程是由哪个进程发展衍生而来的,亦即父进程的代号
PRI :代表这个进程可被执行的优先级,其值 越小越早被CPU执行
NI :代表这个进程的nice值, 优先级的修正值,范围是-20到19,共40个级别。 (每次设置nice值时,PRI都是默认值一般80)

Linux优先级具体做法:

优先级 =  老的优先级(PRI)   +  nice值(NI

修改优先级

输入: top   指令; 进入top后按“r”–>输入进程PID–>输入nice 

 有时需要提高权限,sudo一下即可(前提是:设置过信任用户)

结语

本小节就到这里了,感谢小伙伴的浏览,如果有什么建议,欢迎在评论区评论;如果给小伙伴带来一些收获请留下你的小赞,你的点赞和关注将会成为博主创作的动力。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/52082.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

通过clone的方式,下载huggingface中的大模型(git lfs install)

1、如图&#xff1a;可以手动一个个文件下载&#xff0c;但是那样太慢了&#xff0c;此时&#xff0c;可以点击下图圈起来的地方。 2、点击【Clone repository】&#xff0c;在命令行中&#xff0c;输入【git lfs install】&#xff08;安装了这个&#xff0c;才会下载大文件&a…

Windows 10 安装 PostgreSQL 12.x 报错 ‘psql‘ 不是内部或外部命令 由于找不到文件libintl-9.dll等问题

目录 序言一、问题总结问题 1 psql 不是内部或外部命令&#xff0c;也不是可运行的程序或批处理文件。问题 2 “由于找不到文件libintl-9.dll&#xff0c;无法继续执行代码&#xff0c;重新安装程序可能会解决此问题。“1、卸载2、安装3、安装 Stack Builder &#xff08;这个可…

深入学习 Redis - 深挖经典数据类型之 zset

目录 前言 一、zset 类型 1.1、操作命令 zadd / zrange&#xff08;添加 / 查询&#xff09; zcard&#xff08;个数&#xff09; zcount&#xff08;区间元素个数&#xff09; zrevrange&#xff08;逆序展示&#xff09; zrangebyscore&#xff08;按分数找元素&#…

Java框架学习(三)spring5高级49讲

文章目录 1、BeanFactory与ApplicationContext2、BeanFactory与ApplicationContext的容器实现BeanFactory的容器实现后处理器排序 ApplicationContext的容器实现 3、Bean的生命周期Bean后处理器 4、常见的Bean后处理器5、常见BeanFactory后处理器6、Aware和InitializingBean接口…

Element-plus侧边栏踩坑

问题描述 el-menu直接嵌套el-menu-item菜单&#xff0c;折叠时不会出现文字显示和小箭头无法隐藏的问题&#xff0c;但是实际开发需求中难免需要把el-menu-item封装为组件 解决 vue3项目中嵌套两层template <template><template v-for"item in list" :k…

1.2 网络安全法律法规

数据参考&#xff1a;CISP官方 目录 国家立法体系网络安全法解析网络安全相关法律 一、国家立法体系 1、我国的立法体系 我国的立法体系在网络空间治理中扮演着基础工作的角色。为了应对快速发展的网络技术和威胁&#xff0c;我国采取了多级立法机制来完善网络空间的法律…

腾讯云 Cloud Studio 实战训练营——快速构建React完成点餐H5页面

目录 一、前言 1、什么是腾讯云 Cloud Studio 2、本文实验介绍 二、前期准备工作 1、注册 Cloud Studio 2、初始化工作空间 三、开发一个简版的点餐系统页面 1、安装依赖 1.1、安装 antd-mobile 1.2、安装 less 和 less-loader 1.3、暴露 webpack 配置文件 1.4、安…

FPGA设计时序分析三、恢复/去除时间

目录 一、背景说明 二、工程设计 2.1 工程代码 2.2 综合结果 一、背景说明 ​恢复时间recovery和去除时间removal和setup、holdup类型&#xff0c;不同点是数据信号为控制信号&#xff0c;如复位&#xff0c;清零&#xff0c;使能信号&#xff0c;更多的是异步的复位信号&a…

代理模式——对象的间接访问

1、简介 1.1、概述 由于某些原因&#xff0c;客户端不想或不能直接访问某个对象&#xff0c;此时可以通过一个被称为“代理”的第三者来实现间接访问&#xff0c;该方案对应的设计模式被称为代理模式。 代理模式是一种应用很广泛的结构型设计模式&#xff0c;而且变化很多。…

使用MyBatis(2)

目录 一、定义接口、实体类、创建XML文件实现接口&#xff09; 二、MyBatis的增删改查 &#x1f345;1、MyBatis传递参数查询 &#x1f388;写法一 &#x1f388;写法二 &#x1f388;两种方式的区别 &#x1f345;2、删除操作 &#x1f345;3、根据id修改用户名 &#x…

WPF线程使用详解:提升应用性能和响应能力

在WPF应用程序开发中&#xff0c;线程的合理使用是保证应用性能和响应能力的关键。WPF提供了多种线程处理方式&#xff0c;包括UI线程、后台线程、Task/Async Await和BackgroundWorker。这些方式与传统的Thread类相比&#xff0c;更加适用于WPF框架&#xff0c;并能够简化线程操…

使用pikachu管理工具下的XSS后台进行实战

写在前面的重要提示&#xff1a; Attention&#xff1a;技术没有好坏之分&#xff0c;关键在于使用技术的人或组织。网络安全技术是一把双刃剑 – 作为网络安全人&#xff0c;虽然无法控制头上的帽子是否会变绿&#xff0c;但能控制不让它变黑&#xff1b;无论我们在物质上面对…

深度学习实践——卷积神经网络实践:裂缝识别

深度学习实践——卷积神经网络实践&#xff1a;裂缝识别 系列实验 深度学习实践——卷积神经网络实践&#xff1a;裂缝识别 深度学习实践——循环神经网络实践 深度学习实践——模型部署优化实践 深度学习实践——模型推理优化练习 深度学习实践——卷积神经网络实践&#xff…

VUE之VueRouter页面跳转

参考资料&#xff1a; 参考视频 参考demo及视频资料 VUE之基本部署及VScode常用插件 VUE之基本组成和使用 VUE之Bootstrap和Element-UI的使用 VUE之axios使用&#xff0c;跨域问题&#xff0c;拦截器添加Token Vue Router官网 Vue Router说明&#xff1a; 说明&#xf…

【计算机网络】10、ethtool

文章目录 一、ethtool1.1 常见操作1.1.1 展示设备属性1.1.2 改变网卡属性1.1.2.1 Auto-negotiation1.1.2.2 Speed 1.1.3 展示网卡驱动设置1.1.4 只展示 Auto-negotiation, RX and TX1.1.5 展示统计1.1.7 排除网络故障1.1.8 通过网口的 LED 区分网卡1.1.9 持久化配置&#xff08…

详细介绍 React 中如何使用 redux

在使用之前要先了解它的配套插件&#xff1a; 在React中使用redux&#xff0c;官方要求安装其他插件 Redux Toolkit 和 react-redux Redux Toolkit&#xff1a;它是一个官方推荐的工具集&#xff0c;旨在简化 Redux 的使用和管理。Redux Toolkit 提供了一些提高开发效率的工具…

GO语言日志切割 + 记录调用源

准备工作 日志记录对程序排查问题比较关键&#xff0c;记录下GO中日志选择&#xff0c;从以下出发点考虑&#xff1a; 日志文件能自动切割&#xff0c;以免过大能记录从哪个文件哪行代码调用的&#xff0c;方便排查问题配置简单明了库文件使用人数较多&#xff0c;稳定 经过一段…

ChatIE:通过多轮问答问题实现实命名实体识别和关系事件的零样本信息抽取,并在NYT11-HRL等数据集上超过了全监督模型

项目设计集合&#xff08;人工智能方向&#xff09;&#xff1a;助力新人快速实战掌握技能、自主完成项目设计升级&#xff0c;提升自身的硬实力&#xff08;不仅限NLP、知识图谱、计算机视觉等领域&#xff09;&#xff1a;汇总有意义的项目设计集合&#xff0c;助力新人快速实…

python读取json文件

import json# 文件路径(同目录文件名即可,不同目录需要绝对路径) path 1.json# 读取JSON文件 with open(path, r, encodingutf-8) as file:data json.load(file)#data为字典 print(data) print(type(data))

文件上传

js绕过 打开网页尝试上传一句话木马&#xff0c;发现只能上传图片文件 审计源代码&#xff0c;发现使用一个checkfile函数js对文件类型进行了屏蔽 于是我们修改网页代码&#xff0c;去除返回值的检查函数 checkFile() 上传成功&#xff0c;使用蚁剑连接 连接成功 .htaccess绕…