有两种方式: html
1. command & : 后台运行,你关掉终端会中止运行
2. nohup command & : 后台运行,你关掉终端也会继续运行 linux
1、 简介
Linux/Unix 区别于微软平台最大的优势就是真正的多用户,多任务。所以在任务管理上也有别具特点的管理思想。
咱们知道,在 Windows 上面,咱们要么让一个程序做为服务在后台一直运行,要么中止这个服务。而不能让程序在前台后台之间切换。而 Linux 提供了 fg 和bg 命令,让你轻松调度正在运行的任务。假设你发现前台运行的一个程序须要很长的时间,可是须要干其余的事情,你就能够用 Ctrl-Z ,挂起这个程序,而后能够看到系统提示:
[1]+ Stopped /root/bin/rsync.sh
而后咱们能够把程序调度到后台执行:(bg 后面的数字为做业号)
#bg 1
[1]+ /root/bin/rsync.sh &
用 jobs 命令查看正在运行的任务:
#jobs
[1]+ Running /root/bin/rsync.sh &
若是想把它调回到前台运行,能够用
#fg 1
/root/bin/rsync.sh
这样,你在控制台上就只能等待这个任务完成了。 shell
& 将指令丢到后台中去执行
[ctrl]+z 將前台任务丟到后台中暂停
jobs 查看后台的工做状态
fg %jobnumber 将后台的任务拿到前台来处理
bg %jobnumber 将任务放到后台中去处理
kill 管理后台的任务 bash
2、& spa
在Linux中,当在前台运行某个做业时,终端被该做业占据;而在后台运行做业时,它不会占据终端。可使用&命令把做业放到后台执行。实际上,这样是将命令放入到一个做业队列中了: htm
$ ./test.sh &
[1] 17208 blog
$ jobs -l
[1]+ 17208 Running ./test.sh &
在后台运行做业时要小心:须要用户交互的命令不要放在后台执行,由于这样你的机器就会在那里傻等。不过,做业在后台运行同样会将结果输出到屏幕上,干扰你的工做。若是放在后台运行的做业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:
command >out.file 2>&1 &
在上面的例子中,2>&1表示全部的标准输出和错误输出都将被重定向到一个叫作out.file 的文件中。 当你成功地提交进程之后,就会显示出一个进程号,能够用它来监控该进程,或杀死它。
例:查找名为“httpd.conf”的文件,并把全部标准输出和错误输出重定向到find.dt的文件中:
# find /etc/httpd/ -name "httpd.conf" -print >find.dt 2>&1 &
[2] 7832
成功提交该命令以后,系统给出了它的进程号7832。 对于已经在前台执行的命令,也能够从新放到后台执行,首先按ctrl+z暂停已经运行的进程,而后使用bg命令将中止的做业放到后台运行,例如对正在前台执行的tesh.sh使用ctrl+z挂起它:
$ ./test.sh
[1]+ Stopped ./test.sh 队列
$ bg %1
[1]+ ./test.sh & 进程
$ jobs -l
[1]+ 22794 Running ./test.sh & 字符串
可是如上方到后台执行的进程,其父进程仍是当前终端shell的进程,而一旦父进程退出,则会发送hangup信号给全部子进程,子进程收到hangup之后也会退出。若是咱们要在退出shell的时候继续运行进程,则须要使用nohup忽略hangup信号,或者setsid将将父进程设为init进程(进程号为1)
$ echo $$
21734
$ nohup ./test.sh &
[1] 29016
$ ps -ef | grep test
515 29710 21734 0 11:47 pts/12 00:00:00 /bin/sh ./test.sh
515 29713 21734 0 11:47 pts/12 00:00:00 grep test
$ setsid ./test.sh &
[1] 409
$ ps -ef | grep test
515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh
515 413 21734 0 11:49 pts/12 00:00:00 grep test
上面的试验演示了使用nohup/setsid加上&使进程在后台运行,同时不受当前shell退出的影响。那么对于已经在后台运行的进程,该怎么办呢?可使用disown命令:
$ ./test.sh &
[1] 2539
$ jobs -l
[1]+ 2539 Running ./test.sh &
$ disown -h %1
$ ps -ef | grep test
515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh
515 2542 21734 0 11:52 pts/12 00:00:00 grep test
另外还有一种方法,即便将进程在一个subshell中执行,其实这和setsid殊途同归。方法很简单,将命令用括号() 括起来便可:
$ (./test.sh &)
$ ps -ef | grep test
515 410 1 0 11:49 ? 00:00:00 /bin/sh ./test.sh
515 12483 21734 0 11:59 pts/12 00:00:00 grep test
注:本文试验环境为Red Hat Enterprise Linux AS release 4 (Nahant Update 5),shell为/bin/bash,不一样的OS和shell可能命令有些不同。例如AIX的ksh,没有disown,可是可使用nohup -p PID来得到disown一样的效果。
还有一种更增强大的方式是使用screen,首先建立一个断开模式的虚拟终端,而后用-r选项从新链接这个虚拟终端,在其中执行的任何命令,都能达到nohup的效果,这在有多个命令须要在后台连续执行的时候比较方便:
$ screen -dmS screen_test
$ screen -list
There is a screen on:
27963.screen_test (Detached)
1 Socket in /tmp/uscreens/S-jiangfeng.
$ screen -r screen_test
3、 nohup
若是你正在运行一个进程,并且你以为在退出账户时该进程还不会结束,那么可使用nohup命令。该命令能够在你退出账户以后继续运行相应的进程。nohup就是不挂起的意思( no hang up)。 该命令的通常形式为:
nohup conmmand &
若是使用nohup命令提交做业,那么在缺省状况下该做业的全部输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:
nohup command > myout.file 2>&1
在上面的例子中,输出被重定向到myout.file文件中。
4、.*,?,[...],[!...]等
下面就是这些特殊字符:
* 匹配文件名中的任何字符串,包括空字符串。
? 匹配文件名中的任何单个字符。
[...] 匹配[ ]中所包含的任何字符。
[!...] 匹配[ ]中非感叹号!以后的字符。
当s h e l l遇到上述字符时,就会把它们看成特殊字符,而不是文件名中的普通字符,这样用户就能够用它们来匹配相应的文件名。
1)列出以i或o开头的文件名: #ls [io]*
2)列出log.开头、后面跟随一个数字、而后能够是任意字符串的文件名: #ls log.[0-9]*
3)与例二相反,列出log.开头、后面不跟随一个数字、而后能够是任意字符串的文件名 : #ls log.[!0-9]*
4)列出全部以LPS开头、中间能够是任何两个字符,最后以1结尾的文件名:#ls LPS??1
5)列出全部以大写字母开头的文件名:$ ls [A-Z]* 6)列出全部以. 开头的文件名(隐含文件,例如. profile、.rhosts、.histo ry等): $ ls .*
jobs:查看当前有多少在后台运行的命令
fg:将后台中的命令调至前台继续运行。若是后台中有多个命令,能够用 fg %jobnumber将选中的命令调出,%jobnumber是经过jobs命令查到的后台正在执行的命令的序号(不是pid)
bg:将一个在后台暂停的命令,变成继续执行。若是后台中有多个命令,能够用bg %jobnumber将选中的命令调出,%jobnumber是经过jobs命令查到的后台正在执行的命令的序号(不是pid)
杀死已经启动的程序和普通方式同样:
- pkill -9 name
- killall name
- kill pid
- …