一、进程介绍
1.什么是进程?
进程是已启动的可执行程序的运行实例,进程有以下组成部分:
• 已分配内存的地址空间;
• 安全属性,包括所有权凭据和特权;
• 程序代码的一个或多个执行线程;
• 进程状态。
程序: 二进制文件,静态 /usr/bin/passwd ,/usr/sbin/useradd
进程: 是程序运行的过程, 动态,有生命周期及运行状态。
2.进程的生命周期
父进程复制自己的地址空间(fork)创建一个新的(子)进程结构。每个新进程分配一个,唯一的进程 ID (PID),满足跟踪安全性之需。
任何进程都可以创建子进程。所有进程都是第一个系统进程(操作系统)的后代。
3.进程状态产生的原因
在多任务处理操作系统中,每个CPU(或核心)在一个时间点上只能处理一个进程 。在进程运行时,它对CPU 时间和资源分配的要求会不断变化,从而为进程分配一个状态,它随着环境要求而改变。
4.进程状态
常用状态:
R-running
T-stopping
S-sleeping(休眠)
Z-zombie(非正常情况卡死(未响应)
X死掉,退出的进程
二、静态查看进程ps
1.ps aux输出字段含义:
[root@qianfeng ~]# ps aux | head -2
USER PID %CPU %MEM VSZ RSS TTY STAT START TIME COMMAND
root 1 0.0 0.6 128096 6708 ? Ss 16:20 0:01 /usr/lib/systemd/systemd
字段含义:
- USER: 运行进程的用户
- PID: 进程ID
- %CPU: CPU占用率
- %MEM: 内存占用率
- VSZ: 占用虚拟内存
- RSS: 占用实际内存
- TTY: 进程运行的终端
- STAT: 进程状态
- START: 进程的启动时间
- TIME: 进程占用CPU的总时间
- COMMAND: 进程文件,进程名
2.进程排序:
[root@localhost ~]# ps aux --sort -%cpu //以cpu占比降序排列
3.查看进程的父子关系
[root@localhost ~]# ps -ef
UID PID PPID C STIME TTY TIME CMD
root 1 0 0 10:37 ? 00:00:03 /usr/lib/systemd/systemd --switched-root --sys
root 2 0 0 10:37 ? 00:00:00 [kthreadd]
root 4 2 0 10:37 ? 00:00:00 [kworker/0:0H]
root 6 2 0 10:37 ? 00:00:01 [ksoftirqd/0]
root 7 2 0 10:37 ? 00:00:00 [migration/0]
4.自定义显示字段
[root@localhost ~]# ps axo user,pid,ppid,command | head -3 //自定义显示用户名,pid,ppid,进程文件
USER PID PPID COMMAND
root 1 0 /usr/lib/systemd/systemd --switched-root --system --deserialize 22
root 2 0 [kthreadd]
三、动态查看进程top
1.输出字段含义:
[root@localhost ~]# top -d 1 -p 1206 //一秒刷新一次指定进程1206的动态信息
(1)上半部分:
op - 19:50:46 up 9:12, 6 users, load average: 0.43, 0.16, 0.09
程序名-系统时间 运行时间 登录用户数 cpu负载:1分钟 5 15
Tasks: 218 total, 2 running, 216 sleeping, 0 stopped, 0 zombie
总进程数 运行1 睡眠272 停止0 僵死0
%Cpu(s): 6.0 us, 3.6 sy, 0.0 ni, 90.0 id, 0.0 wa, 0.0 hi, 0.4 si, 0.0 st
cpu使用占比 us用户 sy系统 ni优先级 id空闲 wa等待 hi硬件 si软件 st虚拟机
KiB Mem : 2027940 total, 84264 free, 880448 used, 1063228 buff/cache
物理内存k 总内存 空闲内存 使用内存 缓存硬盘内容
KiB Swap: 2097148 total, 2093044 free, 4104 used. 927524 avail Mem
交换分区(虚拟内存)(硬盘的一部分空间,存放常用数据)
(2)下半部分:
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
进程号 用户 优先级 申请内存 实占内存 共用内存 状态 cpu占比 内存占比 占时 程序名
2.top技巧
[root@qianfeng ~]# top //回车,立刻刷新。按z彩色显示,按F,通过光标设置列的顺序。
[root@localhost ~]# top -d 1 -p 1206 //一秒刷新一次指定进程1206的动态信息。
四、信号控制进程kill
[root@qianfeng ~]# kill -l //列出所有支持的信号
常用信号:
- SIGHUP 重新加载配置
- SIGINT 键盘中断Ctrl+C
- SIGQUIT 键盘退出Ctrl+\,类似SIGINT
- SIGKILL 强制终止,无条件
- SIGTERM 终止(正常结束),缺省信号
- SIGCONT 继续
- SIGSTOP 暂停
20)SIGTSTP 键盘暂停Ctrl+Z
案例:
[root@localhost ~]# ps aux | grep vim
root 17219 0.2 0.2 149716 5540 pts/1 S+ 20:07 0:00 vim 1.txt
root 17252 0.0 0.0 112728 972 pts/2 R+ 20:07 0:00 grep --color=auto vim
[root@localhost ~]# kill -15 17219
[root@localhost ~]# kill -15 17219
bash: kill: (17219) - 没有那个进程
五、进程优先级nice
1.Linux 进程调度及多任务,每个CPU在一个时间点上只能处理一个进程,通过时间片技术,来同时运行多个程序。
2.在top中显示的优先级有两个,PR值和nice值:
NI: 实际nice值。可控值-20----19,数值越小优先级越高。
PR(+20): 将nice级别显示为映射到更大优先级队列,-20映射到0,+19映射到39
[root@localhost ~]# ps axo pid,command,nice --sort=-nice //指定展示序列优先级由低到高。 sort排序
PID COMMAND NI
32 [khugepaged] 19
895 /usr/sbin/alsactl -s -n 19 19
2589 /usr/libexec/tracker-extrac 19
2590 /usr/libexec/tracker-miner- 19
2596 /usr/libexec/tracker-miner- -
2607 /usr/libexec/tracker-miner- -
31 [ksmd] 5
892 /usr/libexec/rtkit-daemon 1
1 /usr/lib/systemd/systemd -- 0
2 [kthreadd] 0
6 [ksoftirqd/0] 0
3.启动具有不同nice级别的进程
默认情况下,启动进程时,通常会继承父进程的 nice级别,默认为0。
[root@localhost ~]# ps axo pid,command,nice | grep sleep //显示睡眠进程的pid,程序名,优先级
17804 sleep 5000 0
17851 sleep 60 0
17861 grep --color=auto sleep 0
[root@localhost ~]# nice -n -10 sleep 9999& //指定程序的优先级
[5] 17874
[root@localhost ~]# renice -5 17804 //修改pid为17804的优先级为-5
17804 (进程 ID) 旧优先级为 0,新优先级为 -5
[root@localhost ~]# ps axo pid,command,nice | grep sleep //再次查询验证
17804 sleep 5000 -5
17874 sleep 9999 -10
17920 sleep 60 0
17922 grep --color=auto sleep 0
六、作业控制jobs
4.jobs查看后台进程。作业控制是一个命令行功能,也叫后台运行。
fg:前台进程:是在终端中运行的命令,占领终端。
bg:后台进程:没有控制终端,它不需要终端的交互。看不见,但是在运行。
[root@localhost ~]# jobs //查看后台进程
[1] 已停止 top -p 1206 -d 1
[2]+ 已停止 top -p 12065 -d 5
[3]- 已停止 top -p 2779 -d 5
[4] 运行中 sleep 5000 &
[5] 运行中 nice -n -10 sleep 9999 &
[6] 运行中 sleep 600000 &
fg不加选项优先调动带“+”,其次为“-”的程序。
[root@localhost ~]# kill %6 //杀死后台进程6
[6] 已终止 sleep 600000
[root@localhost ~]# fg 5 //调动5至前台运行
nice -n -10 sleep 9999
七、虚拟文件系统
虚拟文件系统:采集服务器自身内核,进程运行的状态信息
CPU信息存储文件:/proc/cpuinfo
查询cpu信息:cat /proc/cpuinfo
内存:/porc/meminfo
查询内存信息:cat /porc/meminfo
内核:/proc/cmdline