Linux: 进程和计划任务管理 理论干货

1.0.1 程序,进程,线程之间的关系

1.1.0 进程概述

  • 进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体

1.2.0 应用程序,进程和线程的关系

名称关系
应用程序一个应用程序可以包含一个或者多个进程
进程一个进程包含一个或多个线程
线程线程是执行操作的最小单元
  • 举例:以一个工厂结构举例
    应用程序=工厂
    进程=车间
    线程=工人
    高并发处理==>依赖于多线程操作

1.2.2 程序和进程的关系

  • 程序
    保存在硬盘,光盘等介质中的可执行代码和数据
    静态保存的代码
  • 进程
    在CPU及内存中运行的程序代码
    动态执行的代码
    父子进程:每个进程可以创建一个或多个进程,是一个依赖关系

1.2.3 进程和线程的关系

  • 进程和线程都是由操作系统的程序运行的基本单元,系统利用该基本单元实现系统对应用的并发性

  • 一个程序至少有一个进程,一个进程至少有一个线程

  • 线程的划分尺度小于进程,所以多线程程序的并发性高

  • 进程在执行过程中拥有独立的内存单元,而多个线程共享内存,从而极大的提高了程序的运行效率

  • 线程在执行过程中与进程存在区别

  • 每个独立的线程有一个程序运行的入口,顺序执行序列和程序的出口

  • 但是线程不能够独立执行,必须依存在应用程序中,由应用程序提供多个线程执行控制。

  • 从逻辑角度来看,多线程的意义在于一个应用程序中,有多个执行部分可以同时执行

  • 但操作系统并没有将多个线程看做多个独立的应用,来实现进程的调度和管理以及资源分配

  • 这就是进程和线程的重要区别

  • 进程是具有一定独立功能的程序关于某个数据集合上的一次运行活动,进程是系统进行资源分配和调度的一个独立单位

*线程是进程的一个实体,是CPU调度和分派的基本单位,它是比进程更小的能独立运行的基本单位,线程自己基本上不拥有系统资源,只拥有一点在运行中必不可少的资源(如程序计数器,一组寄存器和栈)但是它可以与同属一个进程的其他线程共享进程所拥有的全部资源

  • 一个线程可以创建和撤销另一个线程

  • 同一个进程中的多个线程之间可以并发执行

1.3.0 查看进程

1.3.1 静态查看 ps命令

  • ps命令,查看静态的进程统计信息(Processes Statistic
  • ps命令是Linux系统中最为常用的进程查看工具,主要用于显示包含当前运行的各进程完整信息的静态快照
ps命令基本格式
ps [选项]  注意:有一些选项时不带“-”前缀的(添加“-”前缀后含义可能会有出入)
a  显示当前终端下的所有进程信息,包括其他用户的进程、与“x”选项结合时将显示系统中所有的进程信息
u  使用以用户为主的格式输出进程信息
x  显示当前用户在所有终端下的进程信息
-e 显示系统内的所有进程信息
-l 使用长(Long)格式显示进程信息
-f 使用完整的(Full)格式显示进程信息
  • 执行不带任何选项的ps命令时,将只显示当前用户会话中打开的进程
[root@localhost ~]# ps
   PID TTY          TIME CMD
  2711 pts/0    00:00:00 bash
  2946 pts/0    00:00:00 ps

  • ps aux命令 以简单列表的形式显示出进程信息
[root@localhost ~]# ps aux
USER        PID %CPU %MEM    VSZ   RSS TTY      STAT START   TIME COMMAND
root          1  0.2  0.3 193700  6836 ?        Ss   22:38   0:01 /usr/lib/systemd/syst
root          2  0.0  0.0      0     0 ?        S    22:38   0:00 [kthreadd]
root          3  0.0  0.0      0     0 ?        S    22:38   0:00 [ksoftirqd/0]
root          4  0.0  0.0      0     0 ?        S    22:38   0:00 [kworker/0:0]
root          5  0.0  0.0      0     0 ?        S<   22:38   0:00 [kworker/0:0H]
root          7  0.0  0.0      0     0 ?        S    22:38   0:00 [migration/0]
root          8  0.0  0.0      0     0 ?        S    22:38   0:00 [rcu_bh]
..以下省略部分内容
  • 上述输出信息中,每一列称为字段或者列或者属性
  • 上述输出信息中,第一行为列表标题,其中个字段的含义如下
    USER: 启动该进程的用户账号信息
    PID: 该进程在系统中的数字ID号,在当前系统中是唯一的
    %CPU:CPU占用的百分比
    %MEN:内存占用的百分比
    VSZ:占用虚拟内存(SWAP)的大小
    RSS:占用常驻内存(物理内存)的大小
    TTY: 表明该进程在哪个终端上运行。“?”表示未知或者不需要终端
    SATA: 显示了进程当前的状态,如S(休眠),R(运行),Z(僵死),<(高优先级),N(低优先级),s(父进程),+(前台进程),l(多线性进程),D(不可休眠进程)对处于僵死状态的进程应该予以手动终止
    START: 启动该进程的时间
    TIME: 该进程占用CPU时间
    COMMAND: 启动该进程的命令的名称
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿辉爱学习

奥利给你的打赏就是我的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值