008-Linux后台进程管理(作业控制:&、jobs、fg、bg、ctrl + z、nohup)

文章目录

前言

1、&

[2、ctrl + z](#2、ctrl + z)

3、jobs

4、fg:将后台进程调到前台执行

5、bg:将一个暂停的后台进程变为执行

6、&和nohup

总结


前言

有时候我们需要将一个进程放到后台去运行,或者将后台程序切换回前台,这时候就用到了我们的作业控制的命令。或者我们希望一个进程在终端退出后还能继续执行,这时候会用到&和nohup命令。


1、&

在命令后面加&表示放到后台运行

bash 复制代码
sleep 100 &

2、ctrl + z

将一个正在执行的前台进程放到后台,并且暂停

3、jobs

查看 当前后台作业(进程),是获取本次bash下的后台作业。 当本次终端退出后,后台作业变成孤儿进程,孤儿进程有系统父进程接管。 当再次连接终端时,原作业与当前终端,不存在关系父子关系,故看不到进程。

bash 复制代码
jobs -l

格式:

jobs 【选项】 【参数】

-l:显示进程的作业号、PID、进程状态、进程命令

-p:仅显示PID

-n:显示进程状态

-r:仅输出运行状态(running)的任务

-s:仅输出停止状态(stoped)的任务

4、fg:将后台进程调到前台执行

bash 复制代码
fg %1

格式:

fg %作业号

作业号可以通过jobs命令获得

5、bg:将一个暂停的后台进程变为执行

bash 复制代码
bg %1

使用 kill -19 将作业1暂停,然后用 bg 命令恢复,也可以用 kill -18 命令

6、&和nohup

&的意思是在后台运行,ctrl + c不会让进程消失,但是要注意, 如果你直接关掉shell后,那么进程会消失。因为&对SIGINT信号免疫,对SIGHUP信号不免疫;

nohup的意思是忽略SIGHUP信号,所以关闭shell,,进程还是存在的(对SIGHUP信号免疫)。 但是,在shell中用Ctrl+c会使进程消失(因为对SIGINT信号不免疫);

所以一般我们会同时使用 & 和 nohup,这样不管是 Ctrl + C 还是 关闭 shell 都不会使进程消失,相当于守护进程。

比如让sleep 1000变为守护进程

bash 复制代码
nohup sleep 1000 >out.log 2>&1 &

>out.log等同于1>out.log(默认是1,如果写成1>out.log结果也是一样),其中1是标准输出的意思。即将命令的标准输出写入out.log中。

2>&1中2是标准错误的意思,&1是表示文件描述符1,就像C++中取地址一样。所以这个符号整体意思是将标准错误(2)重定向到标准输出(1),然后也就一同写入文件out.log中。


总结

本文主要介绍了作业管理的一些命令:&、jobs、fg、bg、ctrl + z、nohup。

相关推荐
2501_94583743几秒前
腾讯云星星海S7,风冷液冷双适配引领绿色算力
服务器
147API1 分钟前
用 clawdbot 做自动化:任务编排、触发器与可观测性
运维·自动化·clawdbot
2501_941982055 分钟前
企微API自动化:外部群推送实现高效自动化
运维·自动化·企业微信
江畔何人初5 分钟前
Linux 重要目录:/boot、/dev、/etc、/home
linux·运维·云原生
Linux运维技术栈8 分钟前
GitLab社区版备份优化:3M包为何是独立完整备份?
运维·git·gitlab
偷学技术的梁胖胖yo10 分钟前
Shell脚本中连接数据库查询数据报错 “No such file or directory“以及函数传参数组
linux·mysql·shell
BullSmall11 分钟前
云计算容灾:CloudDR核心架构解析
运维·系统架构
草莓熊Lotso12 分钟前
Linux 进程等待与程序替换全解析:从僵尸进程防治到 exec 函数实战
linux·运维·服务器·开发语言·c++·人工智能·python
德彪稳坐倒骑驴12 分钟前
PySpark on Linux系统配置 Hadoop3.1.3+Spark3.4.4(PySpark3)
linux·运维·服务器
2501_9419820520 分钟前
企微外部群自动化的最终章:多账号轮巡推送实战指南
运维·自动化·企业微信