linux和unix都是多任务的操作系统,也就是说系统可以同时运行多个任务或者进程。下面我们来说一下在linux或者unix下用来处理多任务的作业控制命令。
什么是作业控制(job control)?
作业控制就是可以停止或者暂停正在执行的程序,还可以使暂停的进程重新开始运行。这些都是可以通过我们的shell程序来实现。
1.创建一个linux/unix 作业(job)
-
root@devops ~]# top &
-
26569
在这个例子中:
-
[1]:表明刚才的作业号是1
-
26569: 这个是进程的ID号
让我们来多创建几个作业:
-
gedit /tmp/test.c &
-
sleep 1000 &
2.列出当初正在后台运行的作业
为了查看当前运行的作业的状态,可以输入下面的命令:
命令输出如下:
-
[root@devops ~]# jobs
-
[1]- Stopped top
-
[2]+ Stopped vim /tmp/test.c
-
[3] Running sleep 1000 &
-
[root@devops ~]# jobs -l
-
[1]- 26650 Stopped (tty output) top
-
[2]+ 26651 Stopped (tty output) vim /tmp/test.c
-
[3] 26653 Running sleep 1000 &
-
[root@devops ~]#
3. 停止或暂停正在运行的作业
当一个程序正在运行的时候,如果想让该程序在后台执行,可以使用[ctrl]+ [z]或者使用kill命令:
下面举一个通过ctrl+z来暂停正在执行的ping命令:
-
[root@devops ~]# ping osetc.com
-
PING osetc.com (42.96.192.124) 56(84) bytes of data.
-
64 bytes from 42.96.192.124: icmp_seq=1 ttl=64 time=0.031 ms
-
64 bytes from 42.96.192.124: icmp_seq=2 ttl=64 time=0.036 ms
-
64 bytes from 42.96.192.124: icmp_seq=3 ttl=64 time=0.033 ms
-
^Z
-
[4]+ Stopped ping osetc.com
-
[root@devops ~]#
4. 恢复暂停的作业到前台去运行
我们可以使用fg命令将暂停在后台的ping进程调到前台来运行,用法如下:
如果想操作所有以“ping”开头的命令行作业,可以使用下面的格式:
示例输出:
-
root@devops ~]# fg %4
-
ping osetc.com
-
64 bytes from 42.96.192.124: icmp_seq=4 ttl=64 time=0.033 ms
-
64 bytes from 42.96.192.124: icmp_seq=5 ttl=64 time=0.030 ms
-
64 bytes from 42.96.192.124: icmp_seq=6 ttl=64 time=0.030 ms
-
64 bytes from 42.96.192.124: icmp_seq=7 ttl=64 time=0.036 ms
-
^C
-
-
[root@devops ~]# fg %ping
-
ping osetc.com
-
64 bytes from 42.96.192.124: icmp_seq=3 ttl=64 time=0.023 ms
-
64 bytes from 42.96.192.124: icmp_seq=4 ttl=64 time=0.031 ms
-
64 bytes from 42.96.192.124: icmp_seq=5 ttl=64 time=0.030 ms
-
64 bytes from 42.96.192.124: icmp_seq=6 ttl=64 time=0.029 ms
-
^C
-
--- osetc.com ping statistics ---
-
6 packets transmitted, 6 received, 0% packet loss, time 10964ms
-
rtt min/avg/max/mdev = .023/0.027/0.031/0.006 ms
5. 恢复后台已暂停的进程继续在后台运行
我们可以使用bg命令将后台挂起的进程重新开始执行,示例如下:
-
[root@devops ~]# jobs
-
[2]- Stopped vim /tmp/test.c
-
[4]+ Stopped ping osetc.com
-
[5] Running sleep 1000000 &
-
[root@devops ~]# kill -s stop %5
-
[root@devops ~]# jobs
-
[2] Stopped vim /tmp/test.c
-
[4]- Stopped ping osetc.com
-
[5]+ Stopped sleep 1000000
从上面示例可以看出,正在运行sleep进程被挂起了。
-
[root@devops ~]# bg %5
-
[5]+ sleep 1000000 &
-
[root@devops ~]# jobs
-
[2]- Stopped vim /tmp/test.c
-
[4]+ Stopped ping osetc.com
-
[5] Running sleep 1000000 &
将挂起在后台的进程重新开始执行
6. 杀掉一个进程
为了杀掉一个linux命令的进程,我们可以输入kill命令加上该进程的作业ID号,用法如下:
示例输出如下:
-
[root@devops ~]# jobs
-
[2]- Stopped vim /tmp/test.c
-
[4]+ Stopped ping osetc.com
-
[5] Running sleep 1000000 &
-
[root@devops ~]# kill %4
-
-
[4]+ Stopped ping osetc.com
-
[root@devops ~]# jobs
-
[2]- Stopped vim /tmp/test.c
-
[4]+ Terminated ping osetc.com
-
[5] Running sleep 1000000 &
-
[root@devops ~]# jobs
-
[2]+ Stopped vim /tmp/test.c
-
-
[5]- Running sleep 1000000 &
-
[root@devops ~]#
7.为什么shell在退出后会杀掉所有的后台作业进程
默认情况下,当前shell在退出的时候会发送一个HUP信号,杀掉所有后台作业,如果想让作业在当前shell退出后任然能保持在后台运行,那么可以在输入disown命令,再退出shell程序。
-
[root@devops ~]# jobs
-
[1]+ Running tail -f /var/log/messages &
-
[root@devops ~]# disown
-
[root@devops ~]# exit
8.使用nohup命令来阻止后台的进程在退出shell后被杀掉
-
[root@devops ~]# nohup tail -f /var/log/messages &
-
[1] 26806
-
[root@devops ~]# exit
9. 查找最近一次执行的作业的进程号
为了查找最近一次执行的作业的进程ID号,可以使用下面的特殊符号:$!
-
[root@devops ~]# jobs -l
-
[1]+ 26832 Stopped (tty output) top
-
[2]- 26833 Running sleep 100000 &
-
[root@devops ~]# echo $!
-
26833
10. wait命令等待作业的完成
wait命令用来等待给定进程ID运行完成,而后执行wait命令后的程序
阅读(1839) | 评论(0) | 转发(0) |