什么是进程?
进程表示程序的一次执行过程,它是应用程序的运行实例,是一个动态的过程。或者可以更简单地描述为:进程是操作系统当前运行的程序。当一个进程开始运行时,就要启动了这个过程。进程包括动态的执行的程序和数据两部分。现代操作系统支持多进程处理,这些进程可以接受操作系统的调度,所以说每一个进程都是操作系统进程资源调度和分配的一个独立的单位。
所有进程都可能存在三种状态:运行态,就绪态,阻塞态。
运行态表示程序当前实际占用着的CPU资源;
就绪态是指程序除CPU之外的一切运行资源都已经就绪,等待操作系统分配CPU资源,只要分配了CPU资源名,即可立即运行;
阻塞态是指程序在运行的过程中由于需要请求外部资源(例如I/O资源、打印机等低速的或同一时刻只能独享的资源)而当前无法继续执行,从而主动放弃当前CPU资源转而等待所请求的资源。
进程之间又存在互斥和同步的关系。互斥也就是说进程间不能同时运行,必须等待一个进程运行完毕,另一个进程才能运行,比如说不可能有两个进程同时使用同一步打印机打印文件。而进程同步指的是进程间通过某种通信机制实现信息交互。现代计算机使用的信号量机制来实现进程间的互斥和同步,它的基本原理是:两个或者多个进程可以通过简单的信号进行合作,一个进程可以被迫在某一位置停止,直到它接受到一个特定的信号。任何复杂的合作需求都可以通过适当的信号结构得到满足。
进程和程序的区别?
程序是一系列动作执行过程的描述,是指令的有序结合,是一个静态的概念;
进程是动态的,进程是程序以及数据在计算机上的一次执行,没有静态的程序也就没有动态的执行。
程序是可以以某种形式保存在存储介质上的,而进程只能在运行时存在于计算机的内存中。
以现实生活为例,如果说做一件事情需要经过很多既定的步骤,这些步骤可以被写成清单静态地列在纸上,那么它们就是广义上的”程序“,而只有真正开始将计划的步骤付诸实施的过程才是”进程“。
ps是一款非常强大的进程查看工具。
该命令语法如下:
ps 参数
-A 列出所有的进程和-e是一样的效果
-a 列出不和本终端有关的所有进程
-w显示加宽可以显示较多的信息
-u 显示有效使用者相关的进程
-aux显示所有包含其他使用者的进程
使用aux参数的输出:
#USER:进程拥有者
#PID:pid
#%CPU:占用的CPU使用率
#%MEM:占用的内存使用率
#VSZ:占用的虚拟内存大小
#RSS:占用的内存大小
#TTY:运行的终端的号码
#STAT:进程状态:
#D:不可中断
#R:运行中
#S:休眠
#T:暂停
#Z:僵尸进程
#W:没有足够的内存可分配
#<:高优先级的行程
#N:低优先级的行程
#START:进程开始时间
#TIME:累计使用CPU的时间
#COMMAND:执行的命令
top - 19:10:55 up 2 days, 11:00, 2 users, load average: 0.00, 0.00, 0.00
Tasks: 30 total, 1 running, 29 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.0%us, 0.0%sy, 0.0%ni,100.0%id, 0.0%wa, 0.0%hi, 0.0%si, 0.0%st
Mem: 524288k total, 114120k used, 410168k free, 0k buffers
Swap: 65536k total, 65536k used, 0k free, 61584k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
22172 root 20 0 136m 364 236 S 0.3 0.1 2:22.08 redis-server
1 root 20 0 19208 376 264 S 0.0 0.1 0:01.61 init
2 root 20 0 0 0 0 S 0.0 0.0 0:00.00 kthreadd/213
3 root 20 0 0 0 0 S 0.0 0.0 0:00.00 khelper/213
113 root 16 -4 10644 4 0 S 0.0 0.0 0:00.00 udevd
458 root 20 0 180m 676 432 S 0.0 0.1 0:13.05 rsyslogd
490 root 20 0 22080 4 0 S 0.0 0.0 0:00.00 xinetd
497 root 20 0 64232 4 0 S 0.0 0.0 0:00.00 saslauthd
498 root 20 0 64232 4 0 S 0.0 0.0 0:00.00 saslauthd
530 root 20 0 80300 444 280 S 0.0 0.1 0:03.73 sendmail
553 smmsp 20 0 76028 392 260 S 0.0 0.1 0:00.03 sendmail
569 root 20 0 114m 324 244 S 0.0 0.1 0:00.51 crond
576 root 20 0 4052 4 0 S 0.0 0.0 0:00.00 mingetty
577 root 20 0 4052 4 0 S 0.0 0.0 0:00.00 mingetty
4501 root 20 0 42420 12 0 S 0.0 0.0 0:00.00 nginx
4502 nobody 20 0 42852 156 88 S 0.0 0.0 0:09.16 nginx
第一行是服务器的基本信息,包括命令刷新时间
第二行是当前系统进程概括
第三行是CPU信息
第四行物理内存的使用状态
第五行是虚拟机内存的使用状态
再往下的所有信息就是动态进程的信息。
PID:进程的ID
USER:进程的所有者
PR:进程优先级
NI:nice值,负值表示高优先级,正值表示低优先级
VIRT:进程使用的虚拟内存总量,单位为Kb,VIRT=SWAP+RES
RES:进程使用的未被换出的物理内存大小,单位为Kb,RES=CODE+DATA
SHR:共享内存大小,单位为Kb
%CPU:上次更新到现在的CPU时间占用百分比
%MEM:进程使用的物理内存百分比
TIME+:进程使用得到CPU时间总计,单位为1/100秒
COMMAND:进程的名称
杀死进程可以使用命令:kill 进程id 或 kill -9 进程id
(之所以-9是因为有些进程单单kill是杀不死的,使用-9表示强制)
查看指定进程可使用该命令: ps -ef|grep 进程名
例如:ps -ef | grep tomcat
killall 进程名 使用该命令可以防止看错或者输错PID而导致的麻烦