linux命令nohup LInux命令设置参数( 六 )


用screen -dmS session name来建立一个处于断开模式下的会话(并指定其会话名) 。
用screen -list 来列出所有会话 。
用screen -r session name来重新连接指定会话 。
用快捷键CTRL-a d 来暂时断开当前会话 。
screen 示例
[root@pvcent107 ~]# screen -dmS Urumchi
[root@pvcent107 ~]# screen -list
There is a screen on:
12842.Urumchi(Detached)
1 Socket in /tmp/screens/S-root.
[root@pvcent107 ~]# screen -r Urumchi
当我们用“-r”连接到 screen 会话后,我们就可以在这个伪终端里面为所欲为,再也不用担心 HUP 信号会对我们的进程造成影响,也不用给每个命令前都加上“nohup”或者“setsid”了 。这是为什么呢?让我来看一下下面两个例子吧 。
1. 未使用 screen 时新进程的进程树
[root@pvcent107 ~]# ping
[1] 9499
[root@pvcent107 ~]# pstree -H 9499
init─┬─Xvnc
├─acpid
├─atd
├─2*[sendmail]
├─sshd─┬─sshd───bash───pstree
│└─sshd───bash───ping
我们可以看出 , 未使用 screen 时我们所处的 bash 是 sshd 的子进程,当 ssh 断开连接时,HUP 信号自然会影响到它下面的所有子进程(包括我们新建立的 ping 进程) 。
2. 使用了 screen 后新进程的进程树
[root@pvcent107 ~]# screen -r Urumchi
[root@pvcent107 ~]# ping
[1] 9488
[root@pvcent107 ~]# pstree -H 9488
init─┬─Xvnc
├─acpid
├─atd
├─screen───bash───ping
├─2*[sendmail]
而使用了 screen 后就不同了,此时 bash 是 screen 的子进程,而 screen 是 init(PID为1)的子进程 。那么当 ssh 断开连接时 , HUP 信号自然不会影响到 screen 下面的子进程了 。
linux后台执行命令:和nohup的用法,确实很实用 当我们在终端或控制台工作时,可能不希望由于运行一个作业而占住linux命令nohup了屏幕,因为可能还有更重要linux命令nohup的事情要做,比如阅读电子邮件 。对于密集访问磁盘的进程,我们更希望它能够在每天的非负荷高峰时间段运行(例如凌晨) 。为linux命令nohup了使这些进程能够在后台运行,也就是说不在终端屏幕上运行,有几种选择方法可供使用 。
:当在前台运行某个作业时,终端被该作业占据;可以在命令后面加上 实现后台运行 。例如:sh test.sh
适合在后台运行的命令有f i n d、费时的排序及一些s h e l l脚本 。在后台运行作业时要当心:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等 。不过 , 作业在后台运行一样会将结果输出到屏幕上,干扰你的工作 。如果放在后台运行的作业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:
这样,所有的标准输出和错误输出都将被重定向到一个叫做out.file 的文件中 。
PS:当你成功地提交进程以后,就会显示出一个进程号,可以用它来监控该进程 , 或杀死它 。(ps -ef | grep 进程号 或者 kill -9 进程号)
nohup:使用命令后,作业被提交到后台运行,当前控制台没有被占用,但是一但把当前控制台关掉(退出帐户时) , 作业就会停止运行 。nohup命令可以在你退出帐户之后继续运行相应的进程 。nohup就是不挂起的意思( no hang up) 。该命令的一般形式为:
如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:
使用了nohup之后,很多人就这样不管了,其实这样有可能在当前账户非正常退出或者结束的时候,命令还是自己结束了 。所以在使用nohup命令后台运行命令之后,需要使用exit正常退出当前账户 , 这样才能保证命令一直在后台运行 。

推荐阅读