程序和进程
程序:保存在硬盘光盘等介质中的可执行代码和数据
进程:在CPU以及内存中运行的程序代码
线程:是操作系统能够进行运算调度的最小单位。它被包含进程之中,是进程中的实际运作单位。
线程和进程的关系
- 进程是操作系统资源分配的基本单位,线程是处理器任务调度和执行的基本单位
- 如果一个进程内有多个线程,则执行过程不是一条线的,而是多线程共同完成的,所以线程是进程的一部分
- 同一进程的线程共享本进程的地址空间和资源,而进程之间的地址空间和资源是相互独立的
- 一个进程崩溃后,在保护模式下不会对其他进程产生影响,但是一个线程崩溃整个进程都死掉
查看进程信息
ps命令 查看静态进程统计信息
ps aux
- a:显示终端上的所有进程,包括其它用户的进程
- u:表示列出进程的用户名
- x:显示所有终端的进程
| 列名 | 意义 | |
|---|---|---|
| USER | 进程的用户 | |
| PID | 进程的id号 | |
| %CPU | 进程占用CPU百分比 | * |
| %MEM | 进程占用内存百分比 | * |
| VSZ | 该进程使用的虚拟内存量(KB) | |
| RSS | 该进程占用的物理内存量(KB) | |
| TTY | 启动进程终端名 | |
| STAT | 该进程的状态 | * |
| START | 该进程启动时间 | |
| TIME | 该进程实际使用CPU运行的时间 | |
| COMMAND | 进程启用的命令 |
STAT:进程的状态
- D:不可中断的休眠状态
- S:处于休眠状态,可被唤醒
- R:正在运行状态
- T:停止状态,可能是在后台暂停或进程处于跟踪调试状态
- Z:僵尸进程,进程已经终止,但部分程序还在内存当中
ps -elf
- -e:显示系统内的所有进程信息
- -l:使用长格式显示进程信息
- -f:使用完整的格式显示进程信息
| 列名 | 意义 |
|---|---|
| F | 内核分配给进程的系统标记 |
| S | 进程的状态 |
| UID | 启动这些进程的用户 |
| PID | 进程的进程ID |
| PPID | 父进程的进程号(如果该进程是由另一个进程启动的) |
| C | 进程生命周期中的CPU利用率 |
| PRI | 进程的优先级(越大的数字代表越低的优先级) |
| NI | 谦让度值用来参与决定优先级 |
| ADDR | 进程的内存地址 |
| SZ | 假如进程被换出,所需交换空间的大致大小 |
| WCHAN | 若该进程在睡眠,则显示睡眠中的系统函数名 |
| STIME | 进程启动时的系统时间 |
| TTY | 进程启动时的终端设备 |
| TIME | 运行进程需要的累计CPU时间 |
| CMD | 进程的启动命令 |
TTY终端
Centos7系统,TTY表示图形界面,tty2-tty6表示文字界面,可以用ctrl+Alt+F1+F6切换。
pts说明是用远程工具连接的,比如xshell,后面的数字代表登录的时间顺序,越小证明登录的越早。
ps -aT
作用:显示所有线程
- -a:显示所有进程pid
- -T:查看线程信息
top 查看动态进程统计信息
第一行基本信息
查看CPU信息
- lscpu
- cat /proc/cpuinfo
- top后按1
load average
load average表示系统负载的平均值,显示的三个数值分别表示1分钟、5分钟和15分钟内的平均负载情况。指单位时间内,系统处于可运行状态和不可中断状态的平均进程数。
查看load average三个命令
- top
- w
- uptime
该项是用来评判CPU平均负载情况的。看工作量的饱和度,当三个数值长时间处于系统CPU数量的70%到80%以上,系统此时处于高运行状态。如果是服务器不够用,那么给服务器升级扩容。也可能是服务器被攻击,或者运行的程序有bug等,需要排查。
第二行进程的信息
僵尸进程数需要重点关注。
第三行CPU的信息
所有CPU的平均信息
按1查看各个CPU的信息
重要关注us,sy,ni,id
第四行内存信息
| 列名 | 意义 | |
|---|---|---|
| PID | 进程id | |
| USER | 进程所有者的用户名 | |
| PR | 优先级 | |
| NI | 谦让度值,负值表示高优先级,正值表示低优先级 | |
| VIRT | 进程使用的虚拟内存总量,单位kb | |
| RES | 进程使用的物理内存大小,单位kb | |
| S | 进程状态 | * |
| %CPU | 上次更新到现在的CPU的间占用百分比 | * |
| %MEM | 进程使用的物理内存百分比 | * |
| TIME+ | 进程使用的CPU时间总计,单位1/100秒 | |
| CONMAND | 命令名/命令行 | * |
top常用命令
| 命令 | 作用 |
|---|---|
| P键 | 根据CPu使用百分比大小进行排序 |
| M键 | 根据驻留内存大小进行排字 |
| N键 | 根据启动时间进行排序 |
| c键 | 切换显示命令名你和完整命令行 |
| h键 | 可以获得top程序的在线帮助信息 |
| k键 | 根据提示输入指定进程的PID号并按Enter键终止对应的进程 |
| q键 | 退出top程序 |
| 数字1键 | 显示CPU个数和状态 |
top -H
top -H:显示所有线程
top -H -p < pid >:显示特定进程中的线程
pgrep 查看进程信息
作用:根据特定条件查询进程pid信息
| 选项 | 作用 |
|---|---|
| -l | 显示进程名,缺省是输出PID号 |
| -U | 指定特定用户 |
| -t | 指定终端 |
pstree 进程树
作用:以树状结构列出进程信息
| 选项 | 作用 |
|---|---|
| -a | 显示完整信息 |
| -u | 列出对应用户名 |
| -p | 列出对应PID号 |
| -ap | 只查看属于指定用户的进程树结构 |
进程控制方式
手动启动
- 前台启动:用户输入命令,直接执行程序,可能占用前台终端
- 后台启动:在命令行尾加入“&”符号
进程的前后台调度
ctrl+Z
作用:将当前进程挂起,即调入后台并停止执行
jobs命令
jobs [ -l ]:查看处于后台的任务列表
fg命令
作用:将后台进程恢复到前台运行,可指定任务序号
终止进程的运行
Ctrl+C组合键
作用:中断正在执行的命令(终止前台正在运行的进程)
kill、killall命令
- kill用于终止指定PID号的进程(kill PID号)
- killall用于终止指定名称相关的所有进程(killall 进程名称)(可能误杀别的进程,如killall vi会误杀vim进程) 注意:停止状态的进程无法被终止
- -9选项用于强制终止
kill(默认是-15)和kill -9区别
- kill -15 代表的信号为 SIGTESM,这是告诉进程你需要被关闭,请自行停止运行并退出
- kill -9代表的信号是 SIGKILL,表示进程被终止,需要立即退出
- kiLl -9会强制杀死该进程,这个信号不能被捕获也不能被忽略
pkill命令
作用:根据特定条件终止相应的进程
常用命令选项
- -U:根据进程所属的用户名终止相应进程
- -t:根据进程所在的终端终止相应进程
调度任务
at 一次性计划任务
用法:at [HH:MM] [yyyy-mm-dd]
atq查看计划
只能按计划列表,看不到详细内容
atrm删除计划
用法:atrm 序号
crontab 周期性计划
- 按照预先设置的时间周期(分、时、日、月、周)重复执行用户指定的命令操作
- 属于周期性计划任务
- 主要设置文件
- 全局配置文件,位于文件: /etc/crontab
- 系统默认的设置,位于目录: /etc/cron.* /
- 用户定义的设置,位于文件:/var/spool/cron/用户名
- 要使用crontab,需要开启systemctl statue cron.service服务
管理crontab计划任务
-
编辑计划任务crontab -e [-u 用户名] (-u缺省时默认是针对当前用户)
crontab任务配置格式:分 时 日 月 周 (全局配置文件中,这边要加用户名) 命令或脚本文件
| 字段 | 说明 |
|---|---|
| 分钟 | 取值为从0到59之间的任意整数 |
| 小时 | 取值为从0到23之间的任意整数 |
| 日期 | 取值为从1到31之间的任意整数 |
| 月份 | 取值为从1到12之间的任意整数 |
| 星期 | 取值为从0到7之间的任意整数,0或7代表星期日 |
| 命令 | 要执行的命令或程序脚本 |
时间数值的特殊表示方法
| 符号 | 作用 |
|---|---|
| * | 表示该范围内的任意时间 |
| , | 表示间隔的多个不连续时间点 |
| - | 表示一个连续的时间范围 |
| / | 指定间隔的时间频率 |
实例:
0 17 * * 1-5 周一到周五每天17:00
30 8 * * 1,3,5 每周一、三、五的8点30分
0 8-18/2 * * * 8点到18点之间每2小时
- 查看计划任务crontab -l [-u 用户名]
- 删除计划任务crontab -r [-u 用户名]