本文共 10435 字,大约阅读时间需要 34 分钟。
进程管理的概念
进程和程序区别
1.程序是静态概念,本身作为一种软件资源长期保存;而进程是程序的执行过程,它是动态概念,有一定的生命期,是动态产生和消亡的。
2.程序和进程无一一对应关系。一个程序可以由多个时程公用;另一一方面,一个进程在活动中有可顺序地执行若干个程序
父子进程的关系
1.子进程是由一个进程所产生的进程,产生这个子进程的进程称为父进程
2.在linux系统中,使用系统调用fork创建进程。fork复制的内容包括父进程的数据和堆栈段以及父进程的进程环境。
3.父进程终止子进程自然终止。
每当运行一个程序,都要运行一个进程 可以用PS查看
第一列的PID为进程标识符,是系统赋予的每个正在执行进程的唯一标识符,最后的CMD是正在执行的进程的名称
前台进程和后台进程
前台进程 在shell提示处理打入命令后,创建一个子进程,运行命令,Shell等待命令退出,然后返回到对用户给出提示符。这条命令与Shell异步运行,即在前台运行,用户在它完成之前不能执行别一个命令很简单,我们在执行这个查找命令时,无法进行其它操作,这个查找就属于前台进程
后台进程
在Shell提示处打入命令,若后随一个&,Shell创建子进程运行此命令,但不等待命令退出,而直接返回到对用户给出提示。这条命令与Shell同步运行,即在后台运行。"后台进程必须是非交互式的" 再来看这个命令就变成了后台进程,我们用同样的条件进行查找,把查找记过放到hzh/test/init.find这个文件中。不影响我们前台其它的操作。 w 查看当前系统信息 [root@bogon cron]# w
14:48:39 up 2:46, 1 user, load average: 0.00, 0.01, 0.00
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
root pts/1 192.168.203.1 12:27 0.00s 0.17s 0.02s w
w显示信息的含义:
JCPU: 以终端代号来区分,该终端所有相关的进程的进程执行时,所消耗的CPU时间会显示在这里
PCPU: cpu执行程序消耗的时间
WHAT: 用户下在执行的操作
load average :分别显示系统在过去1、5、15分钟内的平均负载程度。
FROM: 显示用户从何处登录系统,":0"的显示代表该用户时人X Windows下,打开文本模式窗口登录的
IDLE: 用户闲置的时间,这是一个计时器,一旦用户执行任何操作,该计时器便会被重置
查看个别用户信息:w [用户名]
[root@localhost ~]# w root
23:32:01 up 52 min, 1 user, load average: 0.00, 0.00, 0.00
USER TTY FROM LOGIN@ IDLE JCPU PCPU WHAT
root pts/1 192.168.203.1 22:53 0.00s 0.10s 0.01s w root
ps进程查看命令
进程查看命令:ps
常用选项:
-a:显示所有用户的进程
-u:显示用户名和启动时间
-x:显示 没有控制终端的进程
-e:显示所有进程,包括没有控制终端的进程
-l:长格式显示
-w:宽行显示,可以使用多个w进行加宽显示
应用实例:
ps 查看隶属自己的进程
root@fnngj-virtual-machine:~# ps
PID TTY TIME CMD
1370 pts/0 00:00:00 bash
3185 pts/0 00:00:00 ps
root@root:~# ps -l
F S UID PID PPID C PRI NI ADDR SZ WCHAN TTY TIME CMD
4 S 0 5941 5801 4 80 0 - 1882 wait pts/2 00:00:00 bash
4 R 0 6000 5941 0 80 0 - 1121 - pts/2 00:00:00 ps
看一下上面的选项都指的什么
PID : 进程号
PPLD: 父进程的进程号
TTY : 进程启动的终端
STAT : 进程当前状态(S休眠状态,D不可中断的休眠状态,R运行状态,Z僵死状态,T停止)
NI : 进程优先级
TIME: 进程自从启动以后启用CPU的总时间
COMMAND/CMD:进程的命令名
USER: 用户名
%CPU: 占用CPU时间和总时间的百分比
%MEM: 占用内存与系统内存总量的百分比
实列:
ps -u or -l 查看隶属于自己进程详细信息
root@root:~# ps -u or -l
ps -le or -aux 查看所有用户执行的进程的详细信息
root@root:~# ps le or -aux
ps -aux --sort pid 可按进程执行的时间、PID、UID等对进程进行排序
root@root:~# ps -aux --sort pid
ps -uU fnngj 查看某个用记启动的进程
root@root:~# ps -uU fnngj
ps -le | grep init 查看指定进程信息
root@root:~# ps -le | grep init
kill用法:
关闭进程:kill [进程号]
root@root:~# kill -l
1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP
6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR1
11) SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM 15) SIGTERM
16) SIGSTKFLT 17) SIGCHLD 18) SIGCONT 19) SIGSTOP 20) SIGTSTP
21) SIGTTIN 22) SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ
26) SIGVTALRM 27) SIGPROF 28) SIGWINCH 29) SIGIO 30) SIGPWR
31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+3
38) SIGRTMIN+4 39) SIGRTMIN+5 40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+8
43) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13
48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX- 12
53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-7
58) SIGRTMAX-6 59) SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2
63) SIGRTMAX-1 64) SIGRTMAX
我们看到每个编号对应一个含义,如 9) SIGKILL ;9标注的是SIGKILL ,那么我们可用9来终止进程。
关闭进程:
kill -s 9 [进程号] (强行关闭)
kill -9 [进程号] (强行关闭)
重启进程:
有时候我们需要把进程重新启动一下,可以下面的命令完成。
kill -1 [进程号] (重启进程)
root@root:~# kill -1 3567 重启PID为3567的进程
关闭图形程序:
关闭图形程序: xkill
当你在终端下输入这个命令时,你的鼠标会变成一个小叉子,你只去点你想要关闭的窗口就可以关闭了
其它:
结束所有进程: killall
查找服务进程号: pgrep [服务名称]
关闭进程: pkill [进程名称]
查看我们当前cpu的信息
root@root:~# cat /proc/cpuinfo
查看内存信息
root@root:~# cat /proc/meminfo
查看当前分区的信息
root@root:~# cat /proc/partitions
我们学过操作系统原理的同学都知道,我们系统在执行程序时有会先后顺序的,但为什么我们的电脑可以边听音乐,边聊QQ,边上网,甚至还可以同时挂几个游戏。因为我们CPU运行超快。他可以把每个程序的进程排好队,这个执行一下,那个执行一下。所以,我们会觉得各种程序是并行运行的。
当然,进程也会分个快慢缓急的,所以要对进程分个优先级。同学们在食堂排队打饭,总理来了,这优先级多高啊。同学们纷纷让开,先给总理打。
* 优先级取值范围为(-20,19)
linux给我们提供的优先级的范围为-20到19,我们启动一个进程时,默认的优先级为0 ,-20的优先级为最大,或者说最高。当然,我们在设置的时候可以写-30,但系统默认为-20.
nice命令
指定程序的运行优先级
格式:nice -n command
例如:nice --5 command
renice 命令
改变一个正在运行的进程的优先级
格式: renice n pid
例如:renice -5 777
例子:
[root@bogon cron]# ps -le
[root@bogon cron]# renice -20 [PID]
nohup命令可以在用户退出时继续执行某一进程
一般的命令在用户退登录后就停止执行了,nohup命令可以使进程在用户退出登录后仍旧继续执行,nohup命令将执行后的数据信息和错误信息默认存储到文件nohup.out中
格式:
nohup program &
例子:
[root@bogon cron]# nohup find / -name init* > /hzh/test/find.init.20120520 &
如果我们没指定/hzh/test/find.init.20120520这个保存位置的话,系统默认会把查询的结果放到nohup.out的文件中。我们一般不会去使用默认方式保存。
进程的挂起与恢复
当我们执行一条命令时,发现太慢或输出内容太多,最常用到的做法就是终止(ctrl+c),那么挂起呢?通俗一点就是暂停呗!^_^!!
进程中止(挂起)和终止
挂起(ctrl+z)
终止(ctrl+c)
小知识:系统中有两种运行的进程,我们在前台是看不到的。一种是后台执行的命令,一种就是被暂停的。那我们通过什么方式查看被暂停和后台执行的进程呢?
查看被挂起的进程(jobs)
进程的恢复:
恢复到前台继续运行(fg)
恢复到后台继续运行(bg)
通过top命令查看进程
top命令与前面介绍的ps命令相似,已经介绍了ps,为什么还要top?top有它自己的优点呢。它比ps显示的信息更详细。而且是动态的噢,信息是在不断变化的噢!
[root@bogon ~]# top
top - 12:45:16 up 43 min, 1 user, load average: 0.00, 0.04, 0.06
Tasks: 57 total, 1 running, 56 sleeping, 0 stopped, 0 zombie
Cpu(s): 0.3% us, 0.3% sy, 0.0% ni, 99.3% id, 0.0% wa, 0.0% hi, 0.0% si
Mem: 1034536k total, 232864k used, 801672k free, 60188k buffers
Swap: 1052248k total, 0k used, 1052248k free, 118692k cached
PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
6848 root 15 0 28948 8444 2524 S 0.3 0.8 0:05.44 X
7181 root 16 0 7036 2436 1968 S 0.3 0.2 0:00.26 sshd
7244 root 16 0 1964 976 772 R 0.3 0.1 0:00.45 top
1 root 16 0 3116 544 464 S 0.0 0.1 0:00.97 init
2 root RT 0 0 0 0 S 0.0 0.0 0:00.00 migration/0
3 root 34 19 0 0 0 S 0.0 0.0 0:00.00 ksoftirqd/0
4 root 5 -10 0 0 0 S 0.0 0.0 0:00.03 events/0
5 root 5 -10 0 0 0 S 0.0 0.0 0:00.01 khelper
6 root 5 -10 0 0 0 S 0.0 0.0 0:00.00 kthread
7 root 15 -10 0 0 0 S 0.0 0.0 0:00.00 kacpid
88 root 5 -10 0 0 0 S 0.0 0.0 0:00.01 kblockd/0
89 root 15 0 0 0 0 S 0.0 0.0 0:00.00 khubd
106 root 20 0 0 0 0 S 0.0 0.0 0:00.00 pdflush
107 root 15 0 0 0 0 S 0.0 0.0 0:00.18 pdflush
108 root 25 0 0 0 0 S 0.0 0.0 0:00.00 kswapd0
109 root 6 -10 0 0 0 S 0.0 0.0 0:00.00 aio/0
255 root 25 0 0 0 0 S 0.0 0.0 0:00.00 kseriod
常用选项:
d : 指定刷新的时间间隔
c : 显示整个命令而不仅仅显示命令名
在命令运行的时候按键盘d,会出现如下提示要求你输入刷新的间隔时间
Change delay from 3.0 to: 10(秒)
常用命令:
u : 查看指定用户的进程
k : 终止执行中的进程
h or ? 获得帮助
r: 重新设定进程优先级
s: 改变刷新的时间间隔
W: 将当前设置写入~/.toprc文件中
at 安排作业在某一时刻执行一次
batch 安排作业在系统负载不重时执行一次
cron 安排周期性运行的作业
一次性计划at和batch
at命令指定时间的方式
绝对计时方法:
midnight noon teatime
hh:mm [today]
hh:mm tomorrow
hh:mm 星期
hh:mm MM/DD/YY
相对计时方法:
now+n minutes
mow+n hours
now+n days
用法:
指定在今天下午17:30执行某命令(假设现在时间是下午14:30,2012年1月11日)
命令格式:
at 5:30pm
at 17:30
at 17:20 today
at now+3 hours
at now+180 minutes
at 17:30 12.1.11
at 17:30 1.11.12
好!现格式知道了,玩个实例吧!
[root@bogon ~]# at now+5 minutes
at>
我们定的时间是5分钟之后,现在可以在at下面输入各种任务,保存!5分钟之后执行;不过,我们需要注意,在用命令时最好写命令的绝对路径,为了安全。
[root@bogon ~]# at now+5 minutes
at> /usr/bin/wall < /etc/motd 做一个广播,把etc/motd 文件广播出去
at> 可以继续写其它的计划
at> <EOT>
job 2 at 2012-05-20 13:43 ctrl+d保存计划并退出
是否还担心我们的计划是否启动,通过下面两个命令查看at进程是否正常启动
[root@bogon test]# at -l
3 2012-05-20 13:57 a root
[root@bogon test]# atq
3 2012-05-20 13:57 a root
如果真的没有启动的话,可以通过手工方式重新启动一下
[root@bogon ~]# /etc/rc.d/init.d/atd start
删除at计划任务
[root@bogon test]# at -d
查看at计划任务
[root@bogon test]# ls /var/spool/at/
batch命令
作用:
安排一个或多个命令在系统负载较轻进运行一次(一般情况下负载较轻指平均负载降到0.8以下)
使用方法同at
周期性计划命令crontab
作用:用于生成cron进程所需要的crontab文件
crontab的命令格式
crontab {-l|-r|-e}
-l 显示当前的crontab
-r 删除当前的crontab
-e 使用编辑器编辑当前crontab文件
好多人都觉得周期计划任务设置起来比较麻烦,其实我们只要掌握规律就很好设置。
crontab -e
规则: 把知道的具体的时间添上,不知道的都添加上*
分钟 小时 天 月 星期 命令/脚本
假如,我们每天早上4点要做一下操作,以下面方式表示:
分钟 小时 天 月 星期 命令/脚本
* 18 * * 1,3 [具体的操作]
假如,我们每周一和三下午的6点要做一下操作,以下面方式表示:
分钟 小时 天 月 星期 命令/脚本
* 4 * * * [具体的操作]
案例:在上学的时候都有上机课,周一到周五,下午5点30上课结果。我们需要在5点30发一个通知,5点45自动关机。设定计划任务需要分两步完成,第一步提醒,第二步关机
分钟 小时 天 月 星期 命令/脚本
30 17 * * 1-5 /usr/bin/wall < /hzh/test/guanji.wall
45 17 * * 1-5 /usr/bin/shudown -h now
操作方法:
[root@bogon test]# crontab -e 回车会进入一个vi文本中
根据我上面介绍格式编写内容,然后保存退出
crontab: installing new crontab 表示创建计划成功
通过下面方式进行查看计划:
[root@bogon test]# cd /var/spool/cron
[root@bogon cron]# ls
root
[root@bogon cron]# cat root
30 17 * * 1-5 /usr/bin/shudown -h now
vmstat
vmstat - Report virtual memory statistics
vmstat [options] [delay [count]]
其结果中的内容:
Procs
r: The number of runnable processes (running or waiting for run time).
b: The number of processes in uninterruptible sleep.
Memory
swpd: the amount of virtual memory used.
free: the amount of idle memory.
buff: the amount of memory used as buffers.
cache: the amount of memory used as cache.
inact: the amount of inactive memory. (-a option)
active: the amount of active memory. (-a option)
Swap
si: Amount of memory swapped in from disk (/s).
so: Amount of memory swapped to disk (/s).
IO
bi: Blocks received from a block device (blocks/s).
bo: Blocks sent to a block device (blocks/s).
System
in: The number of interrupts per second, including the clock.
cs: The number of context switches per second.
CPU
These are percentages of total CPU time.
us: Time spent running non-kernel code. (user time, including nice time)
sy: Time spent running kernel code. (system time)
id: Time spent idle. Prior to Linux 2.5.41, this includes IO-wait time.
wa: Time spent waiting for IO. Prior to Linux 2.5.41, included in idle.
st: Time stolen from a virtual machine. Prior to Linux 2.6.11, unknown.
选项:
-s:从/proc/meminfo文件中抽取的信息并加工后输出;
delay:按照deley所指示的时间重复执行vmstat命令,默认单位为秒;
count:重复执行vmstat命令的次数;
pmap:
pmap - report memory map of a process
pmap [options] pid [...]
选项:
-x,--extended:显示扩展的信息
htop,glances,dstat
http://mirrors.sohu.com/fedora-epel/$releasever/$basearch/
htop:
htop - interactive process viewer
htop [-dChusv]
常用选项:
-d #:htop刷新的间隔时间;
-u USERNAME:显示指定用户的进程;
-s COLUME_NAME:根据指定字段进行排序;
交互式命令:
l:显示指定进程打开的文件列表;
t F5:显示进程树结构,以显示进程之间的父子关系;
a:将选定的进程绑定到某指定的CPU核心运行;
glances:
glances - A cross-platform curses-based monitoring tool
glances [-bdmn1] [-t refresh] [-f file] [-o output]
常用选项:
-b:以KByte为单位显示网卡的数据速率;
-d:关闭磁盘I/O模块;
-m:关闭Mount模块;
-n:关闭Network模块;
-1:单独显示每颗CPU核心的数据统计信息;
-t #:设定刷新时间间隔;
-o {HTML|CSV}:为输出数据指定输出的格式;
-f /PATH/TO/OUTPUT_DIR:指定输出文件的路径,glances.html
glances可以工作于C/S模型下:
S:服务器模式
glances -s -B IPADDR
IPADDR:服务器本地的某个IP地址;
C:客户端模式
glances -c IPADDR
IPADDR:远程服务器指定监听的IP地址;
进程之间可以通信的;IPC,Inter-Process Communication
1.signal
2.semaphore
3.shared memory (SHM)
4.socket
dstat:
dstat - versatile tool for generating system resource statistics
dstat [-afv] [options..] [delay [count]]
常用选项:
-c, --cpu:显示CPU相关的信息;
-d, --disk:显示磁盘相关信息;
-g, --page:显示page相关信息;
-n, --net:显示与Interface相关信息;
-y, --sys:显示与系统相关的信息;
--tcp:显示与TCP连接状态相关的信息;
--udp:显示与UDP连接有关的信息;
--ipc:
--raw:
--socket:
--top-cpu:显示最占用CPU资源的进程;
--top-io:显示最占用IO的进程;
本文转自Vincent一马 51CTO博客,原文链接:http://blog.51cto.com/mazhenbo/1951020,如需转载请自行联系原作者