断开ssh链接在后台继续运行命令
转载:http://blog.csdn.net/v1v1wang/article/details/6855552
对于linux运维,我们都是使用ssh登录到服务器,如果我们运行的任务需要很长时间或不间断运行,在我们直接关闭终端窗口或网络不稳定的情况下,任务就会中断,当然这只对于普通程序,不包括如mysqld,httpd这样的守护进程。
原因分析:
- [root@DigMouse ~]# ping 51osos.com > /dev/null &
- [1] 13678
- [root@DigMouse ~]# pstree -H 13678
- init-+-NetworkManager
- |-sshd---sshd---bash-+-ping
- | `-pstree
复制代码
当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程。从上面的例子大家可以看出当前我们所处的 bash 是 sshd 的子进程,当 ssh 断开连接时,HUP 信号会影响到它下面的所有子进程,包括ping进程。
解决思路:
1.让进程运行在新的session(会话)里即不属于此终端的子进程。
2.可以实现让进程忽略HUP信号
解决方法:
1.nohup命令
功能:不挂断地运行命令,忽略HUP信号。
语法:nohup command &
实例:
- [root@DigMouse ~]# nohup ping 51osos.com > /dev/null &
- [1] 13683
- [root@DigMouse ~]# nohup: ignoring input and redirecting stderr to stdout
- [root@DigMouse ~]# ls
- Desktop Downloads nohup.out
- Documents Music Public Videos
- [root@DigMouse ~]# cat nohup.out
- PING cd447.gotoip.net (122.225.57.246) 56(84) bytes of data.
- 64 bytes from 122.225.57.246: icmp_seq=1 ttl=56 time=48.6 ms
- 64 bytes from 122.225.57.246: icmp_seq=2 ttl=56 time=47.8 ms
- 64 bytes from 122.225.57.246: icmp_seq=3 ttl=56 time=49.9 ms
- 64 bytes from 122.225.57.246: icmp_seq=4 ttl=56 time=49.5 ms
复制代码
- [root@DigMouse ~]# ps -ef | grep ping
- root 13683 13655 0 09:33 pts/0 00:00:00 ping 51osos.com
- root 13687 13655 0 09:36 pts/0 00:00:00 grep ping
- [root@DigMouse ~]#
复制代码
关闭此终端,打开另一个终端使用ps命令,仍然可以查看到ping进程。 无论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前目录的 nohup.out 文件中。如果当前目录的 nohup.out 文件不可写,输出重定向到 $HOME/nohup.out 文件中。
#nohup command > command.out 2>&1 &
上面的例子中nohup command输出的内容输出到了command.out文件中,错误内容输出到了标准输出。
2.setsid命令
功能:run a program in a new session在新的会话中运行程序
实例:
- [root@DigMouse ~]# setsid ping 51osos.com > /dev/null
- [root@DigMouse ~]# ps -ef | grep ping
- root 13696 1 0 09:45 ? 00:00:00 ping 51osos.com
- root 13698 13655 0 09:46 pts/0 00:00:00 grep ping
- [root@DigMouse ~]#
复制代码
从上例可以看出ping进程的PID是13696,进程的父ID(PPID)是init而不是当前终端的进程 ID,可与nohup比较。
3.将"&"也放入“()”内执行命令
将一个或多个命名包含在“()”中就能让这些命令在子 shell 中运行
- [root@DigMouse ~]# (ping 51osos.com > /dev/null &)
- [root@DigMouse ~]# ps -ef | grep ping
- root 13702 1 0 09:50 pts/0 00:00:00 ping 51osos.com
- root 13704 13655 0 09:50 pts/0 00:00:00 grep ping
- [root@DigMouse ~]#
复制代码
进程的父ID(PPID)是init而不是当前终端的进程 ID,因而关闭终端无任何影响。
4.disown命令
- 用disown -h jobspec 来使某个作业忽略HUP信号。
- 用disown -ah 来使所有的作业都忽略HUP信号。
- 用disown -rh 来使正在运行的作业忽略HUP信号。
当使用过 disown 之后,会将把目标作业从作业列表中移除,我们将不能再使用jobs来查看它,但是依然能够用ps -ef查找到它。
但是还有一个问题,这种方法的操作对象是作业,如果我们在运行命令时在结尾加了"&"来使它成为一个作业并在后台运行,那么就万事大吉了,我们可以通过jobs命令来得到所有作业的列表。但是如果并没有把当前命令作为作业来运行,如何才能得到它的作业号呢?答案就是用 CTRL-z(按住Ctrl键的同时按住z键)了!
CTRL-z 的用途就是将当前进程挂起(Suspend),然后我们就可以用jobs命令来查询它的作业号,再用bg jobspec 来将它放入后台并继续运行。需要注意的是,如果挂起会影响当前进程的运行结果,请慎用此方法。
- [root@DigMouse ~]# ping 51osos.com > /dev/null
- ^Z
- [1]+ Stopped ping 51osos.com > /dev/null
- [root@DigMouse ~]# jobs
- [1]+ Stopped ping 51osos.com > /dev/null
- [root@DigMouse ~]# bg %1
- [1]+ ping 51osos.com > /dev/null &
- [root@DigMouse ~]# jobs
- [1]+ Running ping 51osos.com > /dev/null &
- [root@DigMouse ~]# disown -h %1
复制代码
- [root@DigMouse ~]# ps -ef | grep ping
- root 13716 13655 0 09:59 pts/0 00:00:00 ping 51osos.com
- root 13734 13655 0 10:01 pts/0 00:00:00 grep ping
复制代码
此时jobs还是能看到ping后台任务的。logout后在另一个终端测试
- [root@DigMouse ~]# ps -ef | grep ping
- root 13716 1 0 09:59 ? 00:00:00 ping 51osos.com
- root 13754 13738 0 10:02 pts/1 00:00:00 grep ping
复制代码
此时Jobs无ping后台任务。PPID变成了1
5.screen命令
此命令非常强大。如果非常多的命令都需要忽略HUP命令,screen可以解决这一问题。screen 提供了 ANSI/VT100 的终端模拟器,使它能够在一个真实终端下运行多个全屏的伪终端。
- 用screen -dmS session name 来建立一个处于断开模式下的会话(并指定其会话名)。
- 用screen -list 来列出所有会话。
- 用screen -r session name 来重新连接指定会话。
- 用快捷键CTRL-a d 来暂时断开当前会话。
- 我的CentOS6.0上没有screen命令,不过可以使用yum安装。
- [root@DigMouse ~]# yum list screen
- Available Packages
- screen.i686 4.0.3-15.el6 base
- [root@DigMouse ~]# yum install screen*
复制代码
Ok,系统有了screen命令了。
- [root@DigMouse ~]# screen -r DigMouse
- [root@DigMouse ~]# ping 51osos.com > /dev/null &
- [1] 13789
- [root@DigMouse ~]# pstree -H 13789
复制代码
此时 bash 是 screen 的子进程,而 screen 是 init(PID为1)的子进程。那么当 ssh 断开连接时,HUP 信号自然不会影响到 screen 下面的子进程了。
断开ssh链接在后台继续运行命令的更多相关文章
- linux 后台执行nohup 命令,终端断开无影响
nohup /root/start.sh & 在shell中回车后提示: [~]$ appending output to nohup.out原程序的的标准输出被自动改向到当前目录下的nohu ...
- 想要远程服务器长时间挂机不断开ssh连接的技巧
使用top命令挂着就好了,top命令执行的“查看系统进程和资源占用”的任务会一直输出动态的数据,一直有数据传输就不会因为长时间挂机而断开ssh链接了,尤其针对于海外服务器,因为高延迟经常出现挂机久了自 ...
- 避免ssh断开导致运行命令的终止:screen
事情是这样的,需要使用ssh登陆服务器,进行工程的编译,结果不知道什么原因ssh出现write failed:broken pipe,掉线了.反复实验了好几次还是这样(白花花的时间啊,又是config ...
- Linux 后台运行命令:nohup 和 &
[参开文章]:nohup 与 & 的区别 1. nohup 1.1 基本概念 将程序以忽略挂起信号的方式运行起来: 不可以免疫 Ctrl + C 的 SIGINT 中断信号: 可以免疫 SI ...
- linux 命令行远程登录 后台运行命令的方法
linux 命令行远程登录 后台运行命令的方法 http://blog.csdn.net/isuker/article/details/55061595 Linux 技巧:让进程在后台可靠运行的几种方 ...
- Linux后台运行命令 nohup command > myout.file 2>&1
Linux命令后台运行 转自北国的雨,谢谢:http://www.cnblogs.com/lwm-1988/archive/2011/08/20/2147299.html 有两种方式:1. comma ...
- nohup 后台运行命令
在Linux上部署zipkin,在SSH客户端执行java -jar zipkin-server-1.21.0-exec.jar,启动成功,在关闭SSH客户端后,运行的程序也同时终止了,怎样才能保证在 ...
- redmine后台运行命令
nohup ruby script/rails server webrick -e production & redmine 3 后台运行命令: nohup bundle exec rail ...
- nobup 与 后台运行命令
1. Linux进程状态:R (TASK_RUNNING),可执行状态&运行状态(在run_queue队列里的状态) 2. Linux进程状态:S (TASK_INTERRUPTIBLE),可 ...
随机推荐
- Elasticsearch:aggregation介绍
聚合(aggregation)功能集是整个Elasticsearch产品中最令人兴奋和有益的功能之一,主要是因为它提供了一个非常有吸引力对之前的facets的替代. 在本教程中,我们将解释Elasti ...
- 30 分钟理解 CORB 是什么
写在前面 前些日子在调试 bug 的时候,偶然发现这么一个警告: Cross-Origin Read Blocking (CORB) blocked cross-origin response htt ...
- Python 爬虫十六式 - 第一式:HTTP协议
HTTP:伟大而又无闻的协议 学习一时爽,一直学习一直爽! Hello,大家好啊,我是Connor,一个从无到有的技术小白.有的人一说什么是HTTP协议就犯愁,写东西的时候也没想过什么是HTTP协 ...
- UVa 122 Trees on the level (动态建树 && 层序遍历二叉树)
题意 :输入一棵二叉树,你的任务是按从上到下.从左到右的顺序输出各个结点的值.每个结 点都按照从根结点到它的移动序列给出(L表示左,R表示右).在输入中,每个结点的左 括号和右括号之间没有空格,相邻 ...
- SpringBoot2.2发行版新特性
Spring Framework升级 SpringBoot2.2的底层Spring Framework版本升级为5.2. JMX默认禁用 默认情况下不再启用JMX. 可以使用配置属性spring.jm ...
- EasyUI datagrid动态加载json数据
最近做一个项目,要求是两张张表可能查找出10多种不同的结果集. 如果想只用一个表格就把全部的结果不同的显示出来那么就肯定不同使用固定的字段名字,要通过动态加载后台返回来的数据把它显示出来就必须动态加载 ...
- rsync aws ec2 pem
How to use aws ec2 pem http://www.anthonychambers.co.uk/blog/rsync-to-aws-ec2-using-.pem-key/9 方法如下: ...
- tcpdump指定IP和端口抓包
如下指定抓www.baidu.com 并且80端口的包 保存到test.cap 可以在Windows下面用wireshark打开 tcpdump 'port 80 and host www.baidu ...
- RotateZoom.cpp——Inter
// RotateZoom.cpp : Defines the entry point for the console application. // #include "stdafx.h& ...
- url的匹配问题
1.例如我当前访问的路径是 127.0.0.1:8000/app01/customer/ 此时我需要在这个界面跳转另外一个界面127.0.0.1:8000/app02/books/,于是我定义一个a标 ...