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

Linux - 进程

一、什么是进程

首先,Linux是一个多用户多进程的操作系统,系统上可以同时运行多个进程。

进程的产生:①是在执行程序或者命令时产生的;②定时任务进程

进程的类型:前台进程/后台进程

前台进程:一个终端界面,一次只能执行一个程序或者命令;

后台进程:可以同时执行多个程序或者命令;

不论前台进程还是后台进程都受限于终端,如果终端被kill,前后台的进程也会被kill


二、进程的状态(STAT)

R        正在运行

S        休眠/静默        ==> 等待运行

Z        僵尸                ==> 父进程无法正常终止子进程/系统资源到达临界值        

T        已经停止         

        Ss        // 父进程

        S<        // 优先级较高的进程

        SN        // 优先级较低的进程

        R+        // 前台的进程组

        SI          // 以线程的方式运行


三、进程查看

常用查询终端命令及进程排序

tty        // 查看当前终端

who     // 查看机器上所有的终端

w         // 查看机器上所有的终端详情

--sort        // 从低到高排序

--sort -      // 从高到低排序

1.查看瞬时的进程状况        ps

①ps -ef

首行,从左往右依次为:

拥有者  进程号  父进程号  cpu占用率  开始时间  终端名  运行时间  命令

②ps aux

首行,从左往右依次为:

拥有者  pid  cpu占用率  内存占用率  占用的虚拟内存大小  驻留内存大小  终端  进程状态

开始时间  运行时间 命令

③ps axo       
// 自定义查看进程的内容,一般携带命令作为查看的内容

④pgrep         // 查询指定的服务或者命令的pid,一般用来查持续运行状态下的服务的pid
⑤pstree        // 查看进程与进程之间的关系

2.查看即使的进程状况        top/htop

top        //top查看进程状况时,默认以cpu占用从高到底进行排序

top        前五行 

第一行:top - 06:18:40 up 3:15, 1 user, load average: 0.06, 0.02, 0.00

含义分别是:系统时间、运行时间、登录终端数、系统负载(三个数值分别为 1 分钟、5 分钟、15 分钟内的平均值,数值越小意味着负载越低)

第二行:Tasks: 365 total, 1 running, 364 sleeping, 0 stopped, 0 zombie

含义分别是:进程总数、运行中的进程数、睡眠中的进程数、停止的进程数、僵尸的进程数。

第三行:%Cpu(s): 0.4 us, 0.5 sy, 0.0 ni, 98.8 id, 0.0 wa, 0.3 hi, 0.0 si, 0.0 st

含义分别是:用户占用资源百分比系统内核占用资源百分比、改变过优先级的进程资源百分比、空闲的资源百分比、等待输入输出的cpu时间百分比、硬中断占用的cpu百分比、软中断占用的cpu百分比和用于虚拟cpu的情况。

第四行:MiB Mem:7790.6 total, 4309.7 free,2571.4 used, 909.5buff/cache

含义分别是:物理内存总量、内存空闲量、内存使用量、作为内核缓存的内存量。

第五行:MiB Swap: 2095.0 total, 2095.0 free, 0.0 used. 4882.7 avail Mem

含义分别是:虚拟内存总量、虚拟内存空闲量、虚拟内存使用量、已被提前加载的内存量。

htop       
==> top的基础上,点击进程信息就能从高到低排序,有高亮效果和搜索功能,支持调整显示信息

四、进程控制

kill 控制进程的方式?

kill 命令通过传递信号来给进程执行相应的操做

 kill -l        //信号列表

常用的信号

1        对于服务而言,可以在不重启或者停止服务的情况下,重新进行配置;

2        中断进程,相当于ctrl+C

9        强制结束进程

15      正常结束进程,先结束子进程,再结束父进程

18      继续进程

20      暂停进程

控制进程的方式

kill        // 结束某个具体进程

pkill      // 

        -u       // 踢出某个终端用户

        -t        // 踢掉某个终端

kiall      // 结束相关的所有进程

xkill      // 图形化/手动点击结束进程


五、进程调度

为什么要进行进程调度?

首先,前台任务和后台任务都会收到终端的影响,结束终端时,也会相应结束终端中的任务。其次,前台进程一个终端只能执行一次,然后当某个进程要求不能受终端影响时,需要将任务不挂起且放到后台运行。

nohup        //不挂起

fg  %任务编号                //将后台任务放到前台就行运行

bg  %任务编号               //指定任务在后台继续运行

&              //将任务放到后台运行

ctrl+c        //结束前台进程

ctrl+z        //把前台任务的进程放到后台停止

jobs            //查后台任务

http://www.lryc.cn/news/377202.html

相关文章:

  • nginx+tomcat负载均衡、动静分离群集【☆☆☆☆☆】
  • MySQL容器部署步骤
  • 在 Ubuntu 18.04.4 LTS上安装 netmap
  • spark 整合 yarn
  • 蓝桥杯十五届国赛模拟题1答案
  • 分布式之日志系统平台ELK
  • git常见错误
  • 构建稳定高效的消息传递中间件:消息队列系统的设计与实现
  • 支持 MKV、MP4、AVI、MPG 等格式视频转码器
  • yum
  • 【单片机毕业设计选题24016】-基于STM32和阿里云的采空区环境监测系统设计
  • Leetcode3179. K 秒后第 N 个元素的值
  • vue3第二阶段的开发文档
  • 【网络安全学习】漏洞扫描:- 02- nmap漏洞扫描
  • Web开发技能树-HTML-class/id/name/tag
  • 据APO Research(阿谱尔)统计,2023年全球乳酸企业产能约119.3万吨
  • 百度文心智能体平台(想象即现实):轻松上手,开启智能新时代!创建属于自己的智能体应用。
  • Linux中ls -lsa 和ls -lst区别
  • TDengine 签约上海晶澳太阳能,助力储能业务平台搭建
  • 【数据结构】选择题
  • 数据库 |试卷八试卷九试卷十
  • 【华为HCIA数通网络工程师真题-构建互联互通的IP网络】
  • Kafka 负载均衡挑战及解决思路
  • 【Java面试】二十一、JVM篇(中):垃圾回收相关
  • 深入理解预处理
  • DSP28335:定时器
  • 系统架构理解
  • uni-app页面的跳转三种方式,功能作用有什么区别?
  • React 通信:深层传递(Props、Context、Children Jsx)
  • 《Windows API每日一练》5.1 键盘基础