linux环境下的各种后台执行

简介: 有时候会需要一些进程后台执行,此处针对各种情况记录一下已知此进程需要后台运行,且此进程还未运行nohup命令: 顾名思义,nohup的用途就是让提交的命令忽略所有的hangup信号。使用方法:nohup COMMAND [ARG]... setsid命令:在一个新的会话中运行命令,从而可以避开当前终端发出的HUP信号。

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

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

  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的使用 (知乎)

目录
相关文章
|
2月前
|
存储 Linux
Linux环境下删除大文件后磁盘空间未释放问题诊断流程。
以上诊断流程涉及Linux底层机制与高级管理技能结合之处,并需要管理员根据实际环境灵活调整诊断策略与解决方案。
112 8
|
3月前
|
Linux 数据安全/隐私保护 iOS开发
推荐Linux环境下效能优良的双向文件同步工具
综合上述条件,对于Linux环境下的双向文件同步需求,Unison 和 Syncthing 是两个非常出色的选择。它们都有良好的社区支持和文档资源,适用于不同规模的环境,从个人使用到商业部署。Unison 特别适合那些需要手动干预同步过程、需要处理文件冲突解决的场景。而 Syncthing 更加现代化,适合需要自动、实时的数据同步与备份的环境。对于选择哪一个,这将取决于个人的使用场景和具体需求。
320 16
|
3月前
|
安全 应用服务中间件 网络安全
在Linux环境部署Flask应用并启用SSL/TLS安全协议
至此,你的Flask应用应该能够通过安全的HTTPS协议提供服务了。记得定期更新SSL证书,Certbot可以帮你自动更新证书。可以设定cronjob以实现这一点。
202 10
|
2月前
|
Ubuntu 安全 Linux
Ubuntu 24.10 发行版登场:Linux 6.11 内核、GNOME 47 桌面环境
Ubuntu 24.10 还带来了 GNOME 47,增强了性能和稳定性,并引入了新功能。此版本的 Ubuntu 还默认在采用 Nvidia 显卡的硬件上切换到 Wayland,并在支持的硬件上默认使用开源的 Nvidia 560 内核模块。 另外需要注意的是,Ubuntu 24.10 是稳定版本,但作为非 LTS 版本,仅支持 9 个月。
|
2月前
|
安全 Linux 网络安全
Linux系统初步设置本地Git环境和生成SSH密钥的步骤。
现在您的Linux系统已经配置好了Git环境,并创建并添加了SSH密钥,可以安全地与远端仓库进行交互,无论是克隆、推送还是拉取操作。此过程确保了数据传输的安全并使版本控制流程更为顺畅。使用Git时应考虑定期更新并管理您的凭据,以确保安全性。
325 0
|
2月前
|
XML 缓存 Linux
在Linux环境下解决Visual Studio Code字体显示异常和字体替换方法。
解决Linux下VS Code字体显示异常,需要对Linux字体渲染机制有所理解,并对VS Code的配置选项进行合理设置。替换字体时则要通过系统字体配置或VS Code设置来完成。通过上述方法,可以有效地解决字体显示问题,从而提升代码编辑的视觉体验。
216 0
|
3月前
|
Kubernetes Linux 网络安全
Rocky Linux 8.9配置Kubernetes集群详解,适用于CentOS环境
初始化成功后,记录下显示的 `kubeadm join`命令。
162 0
|
4月前
|
Ubuntu Linux Shell
Linux环境下VSCode快速安装终极指南:debian/ubuntu/linux平台通用
以上就是在Linux环境下安装VSCode的终极指南,抛开繁复的专业词汇,以平易近人的文字、形象生动的比喻让你轻松学会这一过程。别忘了,你的小伙伴VSCode已经在应用菜单里等你了!
934 23
|
4月前
|
安全 Linux 定位技术
Linux环境下必备的基础命令概览
以上就是Linux系统中的基本命令和工具,掌握它们就能帮你在Linux世界里游刃有余。这其实就像是学习驾驭一辆新车,熟悉了仪表盘,调整好了座椅,之后的旅程就只需要享受风驰电掣的乐趣了。
98 4