后台运行脚本
测试脚本
#!/bin/bash
int=1
while(( $int<=100 ))
do
echo $int
let "int++"
sleep 1
done
1、执行脚本test.sh:./test.sh
2、中断脚本test.sh:ctrl+c
3、在1的基础上将运行中的test.sh,切换到后台并暂停:ctrl+z
4、执行ctrl+z后,test.sh在后台是暂停状态(stopped),使用命令:bg number让其在后台开始运行(“number”是使用jobs命令查到的 [ ]中的数字,不是pid)
1、直接在后台运行脚本test.sh:./test.sh &
2、查看当前shell环境中已启动的任务情况:jobs
3、将test.sh切换到前台运行:fg %number(”number”为使用jobs命令查看到的 [ ] 中的数字,不是pid)
4、中断后台运行的test.sh脚本:先fg %number切换到前台,再ctrl+c;或是直接kill %number
以上两种在后台运行test.sh的方法,当遇到退出当前shell终端时,后台运行的test.sh也就结束了。这是因为以上两种方法使得test.sh在后台运行时,运行test.sh进程的父进程是当前shell终端进程,关闭当前shell终端时,父进程退出,会发送hangup信号给所有子进程,子进程收到hangup以后也会退出。所以要想退出当前shell终端时test.sh继续运行,则需要使用nohup忽略hangup信号。
1、不中断的在后台运行test.sh:nohup ./test.sh &(test.sh的打印信息会输出到当前目录下的nohup.out中)
2、使用jobs可看到test.sh处于running状态
3、使用ps -ef |grep test.sh可查看到正在运行的test.sh脚本进程
4、退出当前shell终端,再重新打开,使用jobs看不到正在运行的test.sh,但使用ps -ef可以看到
在后台不中断的运行test.sh,可以使用nohup忽略hangup信号,或者使用setsid将其父进程改为init进程(进程号为1)
1、不中断的在后台运行test.sh另一个命令:setsid ./test.sh &
2、使用ps -ef |grep test.sh可看到test.sh进程的父进程id为1
其它
command >out.file 2>&1 & 解析:
1、command>out.file是将command的输出重定向到out.file文件,即输出内容不打印到屏幕上,而是输出到out.file文件中。
2、2>&1 是将标准出错重定向到标准输出,这里的标准输出已经重定向到了out.file文件,即将标准出错也输出到out.file文件中。最后一个&, 是让该命令在后台执行。
3、试想2>1代表什么,2与>结合代表错误重定向,而1则代表错误重定向到一个文件1,而不代表标准输出;换成2>&1,&与1结合就代表标准输出了,就变成错误重定向到标准输出。
操作系统中有三个常用的流:
0:标准输入流 stdin
1:标准输出流 stdout
2:标准错误流 stderr
一般当我们用 > console.txt,实际是 1>console.txt的省略用法;< console.txt ,实际是 0 < console.txt的省略用法。
原文链接:https://blog.csdn.net/ruiyelp/article/details/80184249

发表评论