程序:
- 保存在硬盘、光盘等介质中的可执行代码和数据·
- 文件中静态保存的代码
进程:
- 在CPU及内存中运行的程序代码
- 动态执行的代码
- 父、子进程
每个程序可以创建一个或多个进程
load average系统平均负载
load average: 0.00, 0.01, 0.05
系统平均负载 1分钟 5分钟 15分钟查看 load average 的命令有:top w uptime
load average 的值在什么情况可认为是异常的? 当平均负载长时间高于CPU数量的70%时
load average 平均负载高时可能是CPU密集型进程多导致,也可能是I/O繁忙导致。
查看系统指标
CPU top vmstat sar htop atop
内存 free -m vmstat sar top cat /proc/meninfo
IO iostat(磁盘级别) iotop(进程级别) vmstat(系统级别) atop sar
磁盘容量 df -h du
进程 ps top htop atop pidstat
网卡流量 ifconfig iftop atop cat /proc/net/dev
ps aux
ps -elf
ps -lf -T -p <PID>top
top -H -p <PID>pgrep -l <关键词> -U <用户名> -t <终端>
pstree -aup [用户名]
查看静态的进程统计信息:
ps 命令 查看静态的进程统计信息
方法一:ps aux
a:显示现行终端下的所有进程,包括其它用户的进程。
u:显示进程的归属用户及内存的使用情况。
x:显示所有终端的进程。
h:不显示标题列。
各列的解释:
USER: | 进程的用户。 |
PID: | 进程的ID。 |
%CPU: | 进程占用的CPU百分比,占用越高,进程越耗费资源。 |
%MEM: | 占用内存的百分比 |
VSZ: | 该进程使用的虚拟内存量(KB)。 |
RSS: | 该进程占用的实际物理内存量(KB) |
TTY: | 启动进程的终端名。不是从终端启动的进程则显示为 ? |
STAT: | 该进程的状态(D:不可中断的休眠状态;R:正在运行状态;S:处于休眠状态,可被唤醒;T:停止状态,可能是在后台暂停或进程处于跟踪调试状态;Z:僵尸进程,进程已经中止,但是部分程序还在内存当中) |
START: | 该进程被启动时间。 |
TIME: | 该进程实际使用CPU的时间 |
COMMAND: | 进程的名称与参数。 |
方法二:ps -elf
-e:显示系统内的所有进程信息。
-l:使用长格式显示进程信息。
-f:使用完整的格式显示进程信息。
-a:显示现行终端下的所有进程。
-T:查看线程信息。
-C <进程名称>:显示指定进程名的信息。
-p <进程pid>:显示指定pid的进程的信息。
-H:显示树状结构,表示进程间的相互关系。
--no-headers:不显示标题列。
ps -aT 显示所有线程
ps -T -p <pid> 查看指定进程中已经起的线程
ps -L <pid> 查看指定进程中的线程信息
ps aux --sort -%cpu | head -10 按cpu降序排列,-为降序,+为升序,p与%同义
ps aux --sort +pmem | head -n 10 按内存升序排列
ps aux --sort -pcpu,+pmem | head -n 10
各列的解释:
F: | 内核分配给进程的系统标记。 |
S: | 进程的状态。 |
UID: | 启动这些进程的用户。 |
PID: | 进程的进程ID |
PPID: | 父进程的进程号(如果该进程是由另一个进程启动的) |
C: | 进程生命周期中的CPU利用率 |
PRI: | 进程的优先级(越大的数字代表越低的优先级) |
NI: | 谦让度值用来参与决定优先级 |
ADDR: | 进程的内存地址 |
SZ: | 假如进程被换出,所需交换空间的大致大小 |
WCHAN: | 若该进程在睡眠,则显示睡眠中的系统函数名 |
STIME: | 进程启动时的系统时间 |
TTY: | 进程启动时的终端设备 |
TIME: | 运行进程需要的累计CPU时间 |
CMD: | 进程的启动命令 |
僵尸进程:
一个进程结束了,但是如果该进程的父进程已经先结束了,那么该进程就不会变成僵尸进程,因为每个进程结束的时候,系统都会扫描当前系统中所运行的所有进程,看有没有哪个进程是刚刚结束的这个进程的子进程,如果是的话,就由Init来接管它,成为它的父进程,子进程退出后init会回收其占用的相关资源。
但是当子进程比父进程先结束,而父进程又没有回收子进程,释放子进程占用的资源,此时子进程将成为一个僵尸进程。
top 查看进程动态信息
top 命令——查看进程动态信息
第一行是 任务队列信息
11:06:48 系统时间
up 1:22 系统已运行时长
1 user 当前登录用户数
load average: 0.06, 0.60, 0.48 系统负载,即单位时间内系统处理的任务数,后面三个数值分别为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 | 命令名/命令行 |
top常用命令:
P 键:根据CPU使用百分比大小进行排序
M 键:根据驻留内存大小进行排序
N 键:根据启动时间进行排序
c 键:切换显示命令名称和完整命令行
h 键:可以获得 top程序的在线帮助信息
k 键:根据提示输入指定进程的 PID 号并按 Enter 键终止对应的进程
q 键:退出 top 程序
数字1 键:显示CPU个数和状态
top -H:显示所有线程
top -H -p <pid>:显示特定进程中的线程
CPU使用率和CPU负载:
CPU使用率是指CPU在某个时间段内被使用的比例,以百分比表示。反映了CPU的使用强度。
CPU负载是指CPU正在处理的任务数或等待CPU处理的任务数。反映了系统中的任务繁忙程度。
tty终端
Centos7系统,tty1表示图形界面,tty2-tty6表示文字界面,可以用Ctrl+Alt+F1-F6切换。
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早
运行进程:
前台运行:在命令行输入命令,直接运行
后台运行:在命令末尾追加 & 符号。默认情况下通过追加 & 后台运行的进程会随着终端的关闭而自动退出,
可在命令开头位置添加 nohup(格式为nohup 命令 &),可实现后台运行的进程不会随着终端的关闭而自动退出
进程前后台调度:
ctrl + z #将前台进程挂起暂停并调入到后台
jobs -l #查看挂起调度到后台的进程列表和序号
fg <序号> #将挂起到后台的进程调度到前台继续运行
kill 终止进程:
终止进程
kill <PID>
killall <进程名>
pkill <关键词> -U <用户名> -t <终端>
我们经常会用到kill命令去杀死一个进程,但是有时会出现kill不成功的现象,这是就要用到kill -9。
之所以这两个命令会有区别是因为所发送的信号(Signal)是不同的。默认情况下kill命令的参数为-15。kill -15代表的信号为SIGTERM,这是告诉进程你需要被关闭,请自行停止运行并退出;
而kill -9代表的信号是SIGKILL,表示进程被终止,需要立即退出;
因此kill -9表示强制杀死该进程,这个信号不能被捕获也不能被忽略。
kill是如何杀掉进程的?
kill是如何杀掉进程的? 向进程发送信号的方式杀掉进程
kill 默认选项为 -15 ,发送信号 SIGTERM,表示告诉进程自行停止运行并退出,进程可以忽略
kill -9 ,发送信号 SIGKILL,表示进程要立即退出,且不能被捕捉或忽略
kill -3 ,发送信号 SIGQUIT,表示进程自行退出,并打印进程各个线程的堆栈信息,保存路径为 /proc/${pid}/cwd,文件名为 antBuilderOutput.log
kill -1 ,发送信号 SIGHUP,表示进程重新加载配置文件,不退出
at 一次性计划任务
at HH:MM [yyyy-mm-dd] --> 输入命令列表 --> ctrl + d 提交任务 --> atq 查看没执行的任务列表和序号 --> atrm <序号> 删除指定的任务
周期性计划任务
crontab任务配置:
crontab 周期性计划任务
通式:crontab [选项] [file]
周期性计划任务
确保开启 crond 服务
crontab -e [-u 用户] --> 自动对应文件 /var/spool/cron/用户名代表意义 分钟 小时 日期 月份 周 命令
数字范围 0~59 0~23 1~31 1~12 0~7 需要执行的命令周的数字为 0 或 7 时,都代表“星期天”的意思
* 任意时间点
, 多个不连续的时间点
- 连续的时间点
/ 间隔的时间频率文章来源:https://www.toymoban.com/news/detail-855901.htmlcrontab -l [-u 用户] #查看计划任务列表
crontab -r [-u 用户] #清空任务列表文章来源地址https://www.toymoban.com/news/detail-855901.html
到了这里,关于Linux 进程和计划任务管理的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!