这些进程的后台可靠运行命令你都知道了吗

阅读大概需要6分钟 跟随小博主,每天进步一丢丢

当用户注销(logout)或者网络断开时,终端会收到 HUP(hangup)信号从而关闭其所有子进程。因此,我们的解决办法就有两种途径:要么让进程忽略 HUP 信号,要么让进程运行在新的会话里从而成为不属于此终端的子进程。

nohup

只需在要处理的命令前加上 nohup 即可,标准输出和标准错误缺省会被重定向到 nohup.out 文件中。同时可在结尾加上”&”来将命令同时放入后台运行,也可用”>filename 2>&1”来更改缺省的重定向文件名。

如果上面的的命令没看懂,这里有讲解:

ping 就是看网络的连通性,显示和后面网址互送数据包的信息

其中ps是显示瞬间行程的状态,并不动态连续;如果想对进程运行时间监控,应该用 top 工具。

-e 显示所有进程,环境变量 -f 全格式

ps -ef显示全部进程信息

| 表示管道,将前面的信息传到后面,也就是讲进程的信息传到后面

grep 是一个匹配正则表达式的工具,返回存在的那些行。

setsid

nohup 能通过忽略 HUP 信号来使我们的进程避免中途被中断,换个角度思考,如果我们的进程不属于接受 HUP 信号的终端的子进程,那么自然也就不会受到 HUP 信号的影响了。setsid 就能帮助我们做到这一点。

值得注意的是,上例中我们的进程 ID(PID)为31094,而它的父 ID(PPID)为1(即为 init 进程 ID),并不是当前终端的进程 ID。请将此例与nohup 例中的父 ID 做比较。

disown

但是我们经常好这样,把命令放上去了,运行了很久,突然想起来没有考虑上述问题,这该怎么办才能让它避免 HUP 信号的影响呢?

  1. 用disown -h jobspec来使某个作业忽略HUP信号。
  2. 用disown -ah 来使所有的作业都忽略HUP信号。
  3. 用disown -rh 来使正在运行的作业忽略HUP信号。

需要注意的是,当使用过 disown 之后,会将把目标作业从作业列表中移除,我们将不能再使用jobs来查看它,但是依然能够用ps -ef查找到它。

但是还有一个问题,这种方法的操作对象是作业,如果我们在运行命令时在结尾加了”&”来使它成为一个作业并在后台运行,那么就万事大吉了,我们可以通过jobs命令来得到所有作业的列表。但是如果并没有把当前命令作为作业来运行,如何才能得到它的作业号呢?答案就是用 CTRL-z(按住Ctrl键的同时按住z键)了!

CTRL-z 的用途就是将当前进程挂起(Suspend),然后我们就可以用jobs命令来查询它的作业号,再用bg jobspec来将它放入后台并继续运行。需要注意的是,如果挂起会影响当前进程的运行结果,请慎用此方法。

disown 示例1(如果提交命令时已经用“&”将命令放入后台运行,则可以直接使用“disown”)

注释:

jobs 查看后台运行进程

%1 指的是jobs中的序号为1的进程,也可用于kill %1,表示杀死这个进程。

disown 示例2(如果提交命令时未使用“&”将命令放入后台运行,可使用 CTRL-z 和“bg”将其放入后台,再使用“disown”)

注释:

bg 将一个被暂停的命令在后台继续执行

ctrl+z 会是正在运行的命令被暂停并放进后台

screen

如果有大量这种命令需要在稳定的后台里运行,如何避免对每条命令都做这样的操作呢? 此时最方便的方法就是 screen 了。简单的说,screen 提供了 ANSI/VT100 的终端模拟器,使它能够在一个真实终端下运行多个全屏的伪终端。screen 的参数很多,具有很强大的功能,我们在此仅介绍其常用功能以及简要分析一下为什么使用 screen 能够避免 HUP 信号的影响。 使用 screen 很方便,有以下几个常用选项:

  1. 用screen -dmS session name来建立一个处于断开模式下的会话(并指定其会话名)。
  2. 用screen -list 来列出所有会话。
  3. 用screen -r session name来重新连接指定会话。
  4. 用快捷键CTRL-a d 来暂时断开当前会话。

screen 示例

当我们用“-r”连接到 screen 会话后,我们就可以在这个伪终端里面为所欲为,再也不用担心 HUP 信号会对我们的进程造成影响,也不用给每个命令前都加上“nohup”或者“setsid”了。

  1. 未使用 screen 时新进程的进程树

我们可以看出,未使用 screen 时我们所处的 bash 是 sshd 的子进程,当 ssh 断开连接时,HUP 信号自然会影响到它下面的所有子进程(包括我们新建立的 ping 进程)。

  1. 使用了 screen 后新进程的进程树

而使用了 screen 后就不同了,此时 bash 是 screen 的子进程,而 screen 是 init(PID为1)的子进程。那么当 ssh 断开连接时,HUP 信号自然不会影响到 screen 下面的子进程了。

http://www.shuang0420.com 这个是徐阿衡大牛的博客,你们可以去看看,我这篇文章是边看她的文章,边把不清楚的做了更细的笔记。

IELTS a bit

be sensitive to 对...感到敏感;灵敏

inhumane adj. 残忍的;无人情味的

irritation n. 刺激;激怒;兴奋;令人恼火的事

in succession 接连地;连续地

nuisance n. 讨厌的人;损害;麻烦事;讨厌的东西

推荐阅读:

精彩知识回顾

【珍藏版】长文详解python正则表达式

这些神经网络调参细节,你都了解了吗

谈谈我在自然语言处理入门的一些个人拙见

大数定律和中心极限定理的区别和联系

深度学习之激活函数详解

深度学习之卷积神经网络CNN理论与实践详解

深度学习之RNN、LSTM及正向反向传播原理

TreeLSTM Sentiment Classification

基于attention的seq2seq机器翻译实践详解

【干货】基于注意力机制的seq2seq网络

原文发布于微信公众号 - 深度学习自然语言处理(zenRRan)

原文发表时间:2018-05-10

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java3y

操作系统第五篇【死锁】

3054
来自专栏小白安全

批量检测SQL注入工具

0×01 前言 SQL注入,这个类型的漏洞我真的学了好久好久好久好久,即是我刚刚开始接触安全就学习的第一种漏洞,也是一个迄今为止还在学习的漏洞类型,只...

9536
来自专栏黑白安全

绕过CDN获取网站IP地址

基于masscan扫描IP端中开放的80端口,程序自动连接每个IP测试,筛选出符合条件的ip保存到result.txt 后续程序会提供”基于扫描子域名获取IP段...

1123
来自专栏Snova云数仓

gpexpand分析

具体包括不限于以下内容: 创建用户名,设置环境变量,创建数据目录,安装greenplum软件包,解压目录路径。

3.4K6
来自专栏java工会

JVM堆内存使用率持续上升的一种排查思路

最近新版本发布后,在运行一段时间后程序突然无响应了,观察监控,发现JVM堆内存占用在某个时间点突然飙升,最终导致应用无响应:

1270
来自专栏GAN&CV

ubuntu16.04安装caffe cpu版

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_25737169/article/d...

2454
来自专栏Petrichor的专栏

tensorflow: 为什么 tensor型参数 可以接受 非tensor型输入

但是 manual 里面已经写明了 tf.multiply函数 的 参数项输入 必须要是 tensor型 的:

1163
来自专栏ericzli

Jetson TX1上安装Tensorflow Serving遇到的问题总结

本文的目的是分享在TX1上安装Tensorflow Serving时遇到的主要问题,避免重复踩坑。

3633
来自专栏嵌入式程序猿

带你走进飞思卡尔Kinetis Flashloader(5)

上节我们了解了Kinetis Flashloader支持的外设SPI和I2C,今天我们来看支持的外设UART和CAN UART外设 飞思卡尔Kinetis Fl...

2806
来自专栏Python私房菜

实战 | 用aiohttp和uvloop实现一个高性能爬虫

asyncio于Python3.4引入标准库,增加了对异步I/O的支持,asyncio基于事件循环,可以轻松实现异步I/O操作。接下来,我们用基于asyncio...

1563

扫码关注云+社区

领取腾讯云代金券