讲一下后台执行命令,以及作业的前后台调度。
&
方式
Unix/Linux下一般想让某个程序在后台运行,很多都是使用 & 在程序结尾来让程序自动运行。比如我们要运行mysql在后台:
/usr/local/mysql/bin/mysqld_safe --user=mysql &
nohup方式
很多程序并不象mysqld一样可以做成守护进程,可能我们的程序只是普通程序而已,一般这种程序即使使用 & 结尾,如果终端关闭,那么程序也会被关闭。为了能够后台运行,我们需要使用nohup这个命令,比如我们有个start.sh需要在后台运行,并且希望在后台能够一直运行,那么就使用nohup:
nohup /root/start.sh &
在shell中回车后提示:
[~]$ appending output to nohup.out
原程序的的标准输出被自动改向到当前目录下的nohup.out文件,起到了log的作用。
注意:
有时候在这一步会有问题,当把终端关闭后,进程会自动被关闭,察看nohup.out可以看到在关闭终端瞬间服务自动关闭?
原因:每次在nohup执行成功后直接点关闭程序按钮关闭终端。所以这时候会断掉该命令所对应的session,导致nohup对应的进程被通知需要一起shutdown。
解决方式:当shell中提示了nohup成功后还需要按终端上键盘任意键退回到shell输入命令窗口,然后通过在shell中输入exit来退出终端;
nohup命令参考(no hang up)
nohup Command [ Arg ... ] [ & ]
用途:不挂断地运行命令。
描述:nohup 命令运行由 Command 参数和任何相关的 Arg 参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使用 nohup 命令运行后台中的程序。
要运行后台中的 nohup 命令,添加 & ( 表示”and”的符号)到命令的尾部。
>无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。如果没有文件能创建或打开以用于追加,那么 Command 参数指定的命令不可调用。如果标准错误是一个终端,那么把指定的命令写给标准错误的所有输出作为标准输出重定向到相同的文件描述符。
退出状态:该命令返回下列出口值:
126 可以查找但不能调用 Command 参数指定的命令。
127 nohup 命令发生错误或不能查找由 Command 参数指定的命令。
否则,nohup 命令的退出状态是 Command 参数指定命令的退出状态。
nohup命令及其输出文件 ### 使用nohup命令提交作业
如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:
nohup command > myout.file 2>&1 &
在上面的例子中,输出被重定向到myout.file文件中。
fg bg jobs和 Ctrl-Z
假如你发现前天运行的一个程序需要很长的时间,但是需要干前天的事情,你就可以
- 用
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
#这样控制台上就只有等待这个任务完成了
Note
fg
、bg
、jobs
、&
、 ctrl+z
都是跟系统任务有关的,学会了相当的实用
&
最经常被用到 这个用在一个命令的最后,可以把这个命令放到后台执行ctrl + z
可以将一个正在前台执行的命令放到后台,并且暂停jobs
查看当前有多少在后台运行的命令fg
将后台中的命令调至前台继续运行
如果后台有多个命令,可以用 fg %jobnumber
将选中的命令调出,%jobnumber
是通过jobs命令
查到的后台正在执行的命令的序号***(不是pid)
bg
将一个在后台暂停的命令,变成继续执行
如果后台有多个命令,可以用bg %jobnumber
将选中的命令调出,%jobnumber
是通过jobs命令
查到的后台正在执行的命令的序号***(不是pid)
重定向
在 shell 程式中,最常使用的 FD (file descriptor) 大概有三个, 分别是: 0 是一个文件描述符,表示标准输入(stdin) 1 是一个文件描述符,表示标准输出(stdout) 2 是一个文件描述符,表示标准错误(stderr)
在标准情况下, 这些FD分别跟如下设备关联: stdin(0): keyboard 键盘输入,并返回在前端 stdout(1): monitor 正确返回值 输出到前端 stderr(2): monitor 错误返回值 输出到前端
>、»、2>
ls a.txt b.txt 1>file.out 2>file.err
执行后,没有任何返回值. 原因是, 返回值都重定向到相应的文件中了(标准输出写入file.out;标准错误写入file.err),而不再前端显示, 一般来说, “1>” 通常可以省略成 “>”.
ls a.txt b.txt >> file.out
将查询结果追加到file.out文件末尾。
2>&1 、1>&2
- 2>&1 错误返回值传递给1输出通道, &1表示1输出通道.
- 正确返回值传递给2输出通道 &2表示2输出通道 如果此处错写成 1>2, 就表示把1输出重定向到文件2中.
$ ls a.txt b.txt 1>file.out 2>&1
$ cat file.out
ls: b.txt: No such file or directory
a.txt
现在, 正确的输出和错误的输出都定向到了file.out这个文件中, 而不显示在前端。
&
&
是一个描述符,如果1或2前不加&,会被当成一个普通文件; 加上则表示标准FD输出通道
>&2 (即1>&2) 意思是把标准输出重定向到标准错误. 2>&1 意思是把标准错误输出重定向到标准输出。 &>filename 意思是把标准输出和标准错误输出都重定向到文件filename中。
举例如下:
标准错误输出到file.err,并将标准输出也写入该文件file.err
ls a.txt b.txt 2> file.err >&2
标准输出到file.out,并将标准错误输出也写入该文件file.out
ls a.txt b.txt > file.out 2>&1
将标准错误输出 和 标准输出都重定向file.err_or_out文件
ls a.txt b.txt &> file.err_or_out