linux环境下的各种后台执行

有时候会需要一些进程后台执行,此处针对各种情况记录一下

已知此进程需要后台运行,且此进程还未运行

  1. nohup命令: 
    顾名思义,nohup的用途就是让提交的命令忽略所有的hangup信号。
    使用方法:nohup COMMAND [ARG]...

     

  2. setsid命令:
    在一个新的会话中运行命令,从而可以避开当前终端发出的HUP信号。
    使用方法:setsid COMMAND [ARG]...

     

  3. &:
    可以结合()产生一个新的子shell并在这个子shell中将任务放置到后台运行,从而不受当前shell终端的HUP信号影响。
    使用方法:(COMMAND [ARG]... &)
    
    而我通常的使用方式为:
    nohup ./filename.sh > filename.log 2>&1 &
    nohup ./filename.sh &> filename.log &
    三点理由:
    1)nohup保障进程不会被hangup信号异常中断;
    2)将任务放置到后台运行,不占用当前的终端;
    3)将错误输出也打印到log中,默认>只有标准输出,错误输出没有。
  4.  通过screen等命令:
    screen是建立一个新的全屏虚拟会话终端,这个会话只有在手动输入exit的时候才会退出,在这个会话里执行的命令不用担心HUP信号会对我们的进程造成影响,因此也不用给每个命令前都加上“nohup”或“setsid”了,非常适合我们有规划的执行大量的后台任务,可以非常方便的让我们对这些后台任务进行管理。
    
    使用方法:
    screen //立即创建并进入一个会话。
    screen -dmS {name} //建立一个处于挂起模式下的会话,并根据我们的需要指定其会话名称。
    screen -dmS {name} {script} //在建立会话时同时执行指定的命令或脚本
    screen -list //列出所有会话。
    screen -r {name} //以独占方式进入指定会话。
    screen -x {name} //以并行方式进入指定会话。
    ctrl +ad //输入快捷键ctrl +a和d,可暂时退出当前会话。
    exit //进入指定会话后执行exit即可关闭该会话。

     

针对已经运行的进程,需要放置到后台运行

  1. 通过ctrl+z,bg,fg,disown
    通过以下命令,我们可以对放入到后台的命令进行控制
    
    查看当前终端下的后台进程:
    直接执行:jobs
    
    将查看到的某个后台进程放回到前台:
    直接输入:fg {jobid} //这里的{jobid}是通过jobs命令中看到的进程前[]中的数字。
    
    将当前正在前台运行的进程放到后台运行:
    先敲下快捷键:ctrl +z //暂停当前正在运行的进程。
    再执行:bg
    
    终止当前正在前台运行的进程:
    直接敲下快捷键:ctrl +c
    
    disown
    亡羊补牢,为没有使用nohup与setsid的进程加上忽略HUP信号的功能。
    使用方法:
    将当前正在前台运行的进程放到后台运行;
    然后执行disown -h %{jobid} //这里的{jobid}是通过jobs命令中看到的进程前[]中的数字。
  2. reptyr命令+screen命令配合使用:
    reptyr需要单独安装,
    ubuntu(apt-get install reptyr)
    作用:
    把没有办法把后台的进程带到当前的pty里来而不终止任务
    这样我们可以结合screen等将当前正在运行的任务放到后台而不终止
    
    使用:
    screen -S {name} #新建一个screen进程
    ps -ef|grep now_run_proc #获取当前运行进程的PID
    reptyr {pid} #将当前运行的进程切换到screen下运行
    ctrl+a+d #退出screen
    
    此时进程已经放到后台执行,回家喝茶等结果。。

参考,引用说明:

1,Linux 技巧:让进程在后台可靠运行的几种方法 (IBM)

2,Linux运行与控制后台进程的方法:nohup, setsid, &, disown, screen 

3,reptyr的使用 (知乎)

posted @ 2018-01-07 15:57  好好学习运维  阅读(3522)  评论(0编辑  收藏  举报