centos7实现程序的后台运行——多种方案整理

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了centos7实现程序的后台运行——多种方案整理相关的知识,希望对你有一定的参考价值。

参考技术A 相信对服务端有所了解的同学对于 如何让进程后台运行 这个问题都有自己的处理方式,本人零零散散也知道一些方法,但偶尔也会陷入搞混的情况(知其然但不知其所以然,命令就这么用呗,也就不管为什么了)。加上近期有不止一个技术还不错朋友在跟我交流中对于如何处理这个问题产生了一些困惑,我想它可能是一个比较普遍存在的问题,因此打算较为系统地整理一下各种八仙过海的神通,同时也稍微扯一扯一些进程信号的问题。

在shell中通过命令行的方式启动一个server,如何能够让它长久地运行呢?我一旦关了这个shell它就无法服务了,这可不是我们想要的结果,这一节将会介绍各种相关的方法。做各种实验之前,我在 conoha 上申请了一台临时的vps,做完就把它释放了,操作系统是CentOS 7。

说句题外话,conoha这个云服务商个人感觉还不错,性价比很高,虽然可能东京的线路偶尔会丢包比较严重,但新加坡的线路很棒,出入100M带宽不限流量,我自己平时用的就是它。好,扯回来,继续我们的整理。

这篇文章的测试server我们就采用nodejs官网的demo吧:

nohup顾名思义,就是忽略hup信号。hup信号是什么呢,就是当一个shell窗口关闭的时候,会给隶属于它的所有进程发一个hup信号,然后该进程就挂了,除非进程捕获了hup信号,然后做了其它的事情,而不是exit。

使用方式就是在平常的命令前加一个nohup命令:

默认情况下,这个命令会在当前目录下产生一个nohup.out文件作为程序的输出。当然你也可以使用管道的方式将输出重定向到其它地方:

这个符号其实并不能解决本文所提到的问题,它只是一个比较好的辅助方式让控制台重新回到你的掌控中,从而可以继续输入其它命令。
就像这样:

这样进程就不会把shell阻塞住了。

用括号把命令包起来运行,也是一个可以让进程后台运行的方式,它的原理是把进程所隶属的session从当前的shell中解放出来,丢给一个subshell。这样一来,shell关闭发送的hup信号就不会被发到它了。就像这样:

命令 输出 阻塞 关闭shell窗口进程还在 exit退出会话进程还在
node server.js 控制台 是 否
nohup node server.js nohup.out 是 否
(node server.js) 控制台 是 否
node server.js & 控制台 否 否 是
nohup node server.js & nohup.out 否 否 是
(node server.js &)node可用 控制台 否 是 是
setsid node server.js 控制台 否 是 是

SIGHUP :从终端上发出的结束信号.
SIGINT :来自键盘的中断信号 ( ctrl + c ) .
SIGKILL :该信号结束接收信号的进程 .
SIGTERM :kill 命令发出 的信号.
SIGCHLD :标识子进程停止或结束的信号.
SIGSTOP :来自键盘 ( ctrl + z ) 或调试程序的停止执行信号.
SIGQUIT :来自键盘 ( ctrl + \ ) 表示终止前台进程并生成 core 文件.

linux centos程序后台运行

一、将程序放入后台运行

1、在命令行后增加&符号,即可放入后台,此时程序在后台运行

2、在命令运行过程中,按下ctrl+z键,将程序放入后台,此时程序在后台是暂停的

二、查看后台 程序

1、jobs -l

显示结果中:

[数字]:表示工作号,数字越大,表示放入后台的时间越晚(即越近);

+或-:+表示最近(即最后)一个放入后台的工作,恢复时,默认恢复此工作。-表示倒数第二个放入后台的工作。其他的工作没有+或-号。

三、将工作恢复到前台

fg %工作号:
%可省略,工作号不是PID

四、将后台暂停的工作恢复到后台运行

bg %工作号:
此工作不能和前台有交互,否则不能恢复到后台运行

以上是关于centos7实现程序的后台运行——多种方案整理的主要内容,如果未能解决你的问题,请参考以下文章

[转载][整理]解决SSH退出登陆后保持进程继续在后台运行

vue后台管理系统实践方案总结

vue后台管理系统实践方案总结

centos7 root登录后 所有的命令都失效,请问有人知道是怎么回事吗?

防重复提交实现方案

整理在Spring IOC容器初始化后可以处理特定逻辑的多种实现方式