进程与计划任务管理

一、查看进程

进程:指在系统中能独立运行并作为资源分配的基本单位,它是由一组机器指令、数据和堆栈等组成的,是一个能独立运行的活动实体。

进程是运行的查看进程 linux程序

1.程序

  • 保存在硬盘、光盘等介质中的可执行代码和数据
  • 文件中静态保存的代码

2.进程控制块包括哪几部分内容进程

  • 在CPU及内存中运行的程序代码
  • 动态执行的代码
  • 父、子进程:

每个程序进程控制实验报告总结可以创建一个linux系统安装或多个进程

3.线程

1、一个进程可以有linux多个线程,但至少有一个线程;而一个线程只能在一个进程的地址空间内活动;一个线程可以创建和撤销另一个线程;同一个进程中的多个线程之间可以并发执行。

2、资源分配给进程,计划任务管理进程控制块一个进程的所有线程共享该进程所有资源。

3、CPU分linux必学的60个命令配给线程,即真正在处理器运行的是线程。

4、线程在执行过程中需要协作同步,不同进程的线程间要利用消息通信的办法实现同步。

注:进程是操作系统最基本的资源拥有单位和调度单位,线程是linux操作系统基础知识程序执行的最小单进程控制实验报告总结位;通常查看进程占用端口都是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度linux重启命令的基本单位

进程间通信方式:(1)消息传递(进程控制原语2)共享存储(3)管道通linux必学的60个命令

4.查看查看进程占用端口进程命令

1.ps命令

查看静态的进程统计信息
ps aux
a:显示终端上的所有进程,包括其他用户的进程
u:表示列出进程的用户
x:显示所有终端的进程
各列的解释
USER:进程的用户
PID:进程的ID。
%CPU:进程占用的CPU百分比。
%MEM:占用内存的百分比。
VSZ:该进程使用的虚拟内存量(KB)
RSS:该进程占用的物理内存量(KB)
TTY:启动进程的终端名。不是从终端启动的进程则显示为? pts代表使用远程连接工具
STAT:该进程的状态(D:不可中断的休眠状态;R:正在运行状态;S:处于休眠状态,可被唤醒;T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;z:僵尸进程,进程已经中止,但是部分程序还在内存当中)
START:该进程被触发启动时间。
TIME:该进程实际使用CPU运行的时间。
COMMAND:进程的启动命令。


                                            进程与计划任务管理

ps -elf
-e:显示系统内的所有进程信息
-l:使用长格式显示进程信息
-f:使用完整的格式显示进程信息
-a:显示所有进程pid
-T:查看线程信息
ps -aT 显示所有线程
各列的解释
F:内核分配给进程的系统标记。
S:进程的状态。
UID:启动这些进程的用户。
PID:进程的进程ID。
PPID:父进程的进程号(如果该进程是由另一个进程启动的)。
C:进程生命周期中的CPU利用率。
PRI:进程的优先级(越大的数字代表越低的优先级)
NI:谦让度值用来参与决定优先级。
ADDR:进程的内存地址。
SZ:假如进程被换出,所需交换空间的大致大小。
WCHAN:若该进程在睡眠,则显示睡眠中的系统函数名。
STIME:进程启动时的系统时间。
TTY:进程启动时的终端设备。
TIME:运行进程需要的累计CPU时间。
CMD:进程的启动命令。

僵尸进程:
一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。
但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。


                                            进程与计划任务管理

2.top命令

查看动态的进程排名信息  top
会动态更新 默认为5秒一更新
第一行 任务队列信息
13:009:58 系统时间 up 1 day,4:40 系统已运行时长 1 user 当前登录用户数 load average:0.00 0.01,0.05
系统负载,即单位时间内系统处理的任务数,后面三个数值分别为1分钟、5分钟、15分钟到现在的平均值
第二行 进程信息
Tasks 总进程数;running 正在运行的进程数;sleeping 休眠的进程数;stopped 中止的进程数;zombie 僵死的进程数
第三行 CPU的信息
us 用户占用;sy 内核占用;ni 优先级调度占用;id 空闲CPU,要了解空闲的CPU百分比,主要看%id 部分
wa I/O等待占用;hi 硬件中断占用;si 软件中断占用;st 虚拟化占用
第四行 内存的信息
total 总内存空间;free 空闲内存;used 己用内存;buff/cache 物理内存和交换内存的缓冲区总和
第五行为交换空间的信息
total 总交换空间;free 空闲交换空间;used 己用交换空间;avail Mem 可用物理空间
进程信息区各列解释:
PID 进程id
USER 进程所有者的用户名
PR 优先级
NI 谦让度值。负值表示高优先级,正值表示低优先级
VIRT 进程使用的虚拟内存总量,单位kb
RES 进程使用的物理内存天小,单位kb
SHR 共享内存大小,单位kb
S 进程状态
%CPU 上次更新到现在的CPU时间占用百分比
%MEM 进程使用的物理内存百分比
TIME+ 进程使用的CPU时间总计,单位1/100
COMMAND 命令名/高令行
常用命令:
P键:根据CPU使用百分比大小进行排序
M键:根据驻留内存大小进行排序
N键:根据启动时间进行排序
C键:切换显示命令名称和完整命令行
h键:可以获得top程序的在线帮助信息
k键:根据提示输入指定进程的PID号并按Enter键终止对应的进程
q键:退出top程序
数字1键:显示cPu个数和状态
top -H:显示所有线程
top -H -p <pid>:显示特定进程中的线程


                                            进程与计划任务管理

查看load average的方法

top;w;up系统/运维time

3.pgrep 命令

根据特定条件查询进程PID信息
pgrep ssh -l -l 显示进程名 不加只输出PID号
-U 指定特定用户 -t指定终端】


                                            进程与计划任务管理

4.ps查看进程占用端口tree 命令

以树形结构列出进程信息
pstree -aup pstree -ap tyx 指定用户显示
-a:显示完整信息
-u:列出对应用户名
-p:列出对应PID号


                                            进程与计划任务管理


                                            进程与计划任务管理


                                            进程与计划任务管理

二、进进程控制块中包含程的控制

1.手动启动

  • 前台启动:用户输入命令,直接执行程序
  • 后台启动:计划任务管理在命令行尾加入“&”符号
cp -r /mnt /root/&     内容过大时进行后台处理
jobs -l 可用来查看

2.调度启动

  • 使用at命令,设置一次性计划任务
  • 使用crontab命令,设置周期性任务
Ctrl+Z组合键:将当前进程挂起,即调入后台并停止执行
jobs命令:jobs [-l] 查看处于后台的任务列表
fg命令:将后台进程恢复到前台运行,可指定任务序号


                                            进程与计划任务管理


                                            进程与计划任务管理

3.终止进程的运行

  • Ctrl+进程控制实验C组合键:中断正在执行的命令
  • Kill、Killall命令

Kill用系统运维工程师于终止指定PID号的进程

killall用于终止指定名称相关的所有进程

-9选项用于强制终止 (默认为15)

  • p系统运维主要做什么kill命令
  1. 根据特定条件进程控制终止相应的进程
  2. 常用命令选项

-U

根据进程所属的用户名终止相应进程

-t

根据进程所在的终端终止相应的进程


                                            进程与计划任务管理

三、计划任务管理

1.at命令

at 命令
一次性计划任务
格式
at HH:MM yyyy-mm-dd (yyyy-mm-dd不加表示当天)
at> 命令
按Ctrl+D 提交任务
示例
at 21:30
at>shoutdown -h now 在当天21:30时关机
按Ctrl+D提交任务
atq 查看未执行的任务列表
atrm 1 删除第一条任务


                                            进程与计划任务管理


                                            进程与计划任务管理

2.crontab命令

按照预先设置的时间周期(分钟、小时、天、月:)重复执行用户指定的命令操作
属于周期性计划任务
主要设置文件:
全局配置文件,位于文件:/etc/crontab
系统默认的设置,位于目录:/etc/cron.*/
用户定义的设置,位于文件:/var/spool/cron/用户名
编辑计划任务:crontab -e -u 用户名 (不加-u默认针对当前用户)
查看计划任务:crontab - -u 用户名
删除计划任务:crontab -e -u 用户名


                                            进程与计划任务管理

要执行的命令或程序脚本

字段

说明

分钟

取值从0~59之间命令来自剃刀党英语的任意整数

小时

取值从0~23之间的任意整linux系统安装

日期

取值从1~31之间的任意整数

月份

取值从1linux是什么操作系统~系统/运维12之间的任意整数

星期

取值从0~7之间的任意整数,0或7代表星期日

命令

*表示该范围内的任意时间

,表示间隔的多个不连续时间点

-表示一个连续的时间范围

/指定间隔的时间频率

应用示例
0 17 * * 1-5 周一到周五每天17:00
0 * */3 * * 每3天每个小时0分
0 8-18/2 * * * 8点到18点每2个小时
方法1:crontab -e 0 04 * * 1-5 ls-l
方法2:echo '0 04 * * 1-5 /user/bin/systemctl httpd restart' >> /var/spool/cron/root