Linux上后台保持Terminal交互运行的三种方式:nohub、screen和tmux
阅读原文时间:2023年07月10日阅读:2

镜像下载、域名解析、时间同步请点击 阿里云开源镜像站

后台运行

Linux上,如果一个进程需要保持后台运行,尤其是在Linux服务器上,后台运行程序、避免因为SSH连接断开而导致进程停止运行时,该怎么办?

很简单,相信很多人会选择systemd注册进程,但是如果只是临时使用,比如:wget在下载文件。或者只是偶尔使用呢?(毕竟,systemd配置还是挺麻烦的……)

其实,大体有三种方法:

  • nohup &(Ctril+Z)
  • screen虚拟终端【推荐】
  • tmux终端复用器【推荐】

使用场景

什么情况下Linux上需要在终端(terminal)上,后台运行Linux呢?

举例:Minecraft服务器运行、Springboot打包的jar……

这个时候,我们终端关闭->SSH断开->JavaWeb随即停止运行。这个是因为,我们退出SSH连接时,发送SIGHUP信号给控制会话,进而导致我们前台会话上的程序停止运行。

所以,我们需要用一些方法,后台保存运行终端的交互。

Nohup

Nohup全称是:no hang up,中文直接以上就是不挂起,为什么是no hang up呢?其实很简单,举个例子:我们前台运行Aria2进程:

这个时候,Aria2进程交互就是挂起(hang up),保持在终端前台。

而Nohup(no hang up),就是这样的:

这样,终端没有输出内容,就是Nohup,对应地,我们可以在当前目录下看到终端输出内容:

当然,仅仅只有nohup是不够的,还需要&参数

这里的&参数,可不是“和”的意思,是让当前内容后台运行。

有了&参数,接下来,我们使用nohup就可以后台运行了:

# zsh aria2Strat.sh为我用zsh启动Aria2
nohup zsh aria2Strat.sh &

这样就可以后台运行Aria2了。你可以输入jobs命令查看后台的进程:

jobs

不过如果进程没有守护进程,或者是回发SIGHUP信号的话…关闭或者退出终端依旧会终止进程(这里就是终止Aria2进程)。

如果,我们的脚本或程序,即没有守护线程,也没有SIGHUP信号呢?其实还是有两种方法,首先看Noup的选择参数:

  • disown:在sh中,可以通过disown -h job名忽略 SIGHUP 信号;disown命令将移除job表中特定的job,这也意味着该job不再接受任何信号。
  • Control-Z:通过 Control+Z 可以将当前进程挂起(放置后台并暂停运行),可通过fg 命令恢复至前台,也通过bg将挂起的进程后台运行。
  • shopt:shopt huponexit命令让sh在登录用的shell退出时,发送SIGHUP信号至所有的jobs。

也就是,我们可以使用disown或者Control-Z方式,在终端关闭情况下,后台运行进程。

Control-Z

这个方法其实很简单,用了这个方法,甚至不需要&参数(如果不需要保留终端上输出日志到nohup.out,不加nohup也可以):

# 运行Aria2
nohup zsh aria2.sh

之后,按Control+Z(Windows用户应该是Ctril+Z):

这个时候,Aria2已经暂停服务并移动至后台,我们可以使用jobs命令查看:

jobs

之后,我们可以使用bg命令,运行Aria2后台继续执行:

bg %1

其中,%1指代[1]

相当于,用了&参数,就做了Control+Zbg %1

回到这个后台进程,输入:

fg %1

disown参数

如果Control+Z方法不行,我们可以使用disown参数:

nohup zsh aria2Start.sh & disown

这个时候,就可以退出终端了。

当然,这种方法……无法回到后台进程的控制台内了~

screen虚拟终端

我其实更推荐screen,这个算是一个终端神器

首先,我们安装screen:

# Debian
apt-get install screen
# CentOS 8以前
yum install screen
# CentOS 8以后
yum install epel-release
yum install screen

官方给的方法是

screen -S #虚拟终端名字

比如:

但是,我更推荐使用screen -R #虚拟终端名字来创建。以后有机会说原因。

创建好后:

在这个界面,运行程序即可:

之后,按Control+a进入screen的指令接受,再按d即可回到主终端。这个时候,关闭终端,Aria2也不会停止运行。

查看已经存在的screen很简单,输入:

screen -ls

即可查看:

刚刚我们查看了已经存在的screen,接下来我们重新进入,有两种方式:

  • PID进入:使用screen -r #PID即可进入
  • screen名:使用screen -R #screen名即可进入

比如,我使用screen - R进入:

screen -R aria2

tmux终端复用器

最后,我们看看tmux终端复用器,这个本质上和screen差不多(我个人还是喜欢用screen,别的原因,就是习惯了……)

首先是安装tmux

# centos
sudo yum install tmux
# ubuntu
sudo apt-get install tmux

之后,一般就可以使用了。

创建tmux终端很简单,也是一条命令:

tmux new -s demo

其中,demo为自定义名称。创建好后:

之后,按Control+btmux指令接受,再按d即可回到主终端。这个时候,关闭终端,运行的程序也不会停止运行。

和screen一样,tmux查看已经存在的tmux也很简单:

tmux ls

重新进入的方法很简单:

tmux -a -t demo

这样就进入成功了:

总结

本文主要提供三种非systemd注册的方式,后台运行Linux进程的方法,个人更推荐使用screen或者tmux,有机会单独给大家讲讲这两个命令。

有小伙伴会问screen和tmux具体区别,其实使用起来基本没区别,细节的话,就是screen进入后,可以无限套娃新的screen……tmux里可不会让使用者这样套娃……

本文转自:https://juejin.cn/post/7055128927953485832

手机扫一扫

移动阅读更方便

阿里云服务器
腾讯云服务器
七牛云服务器

你可能感兴趣的文章