Linux_控制作业(管理)
一、作业控制
1、作业控制与回话
1️⃣:作业控制是shell的一种功能,它允许单个shell实例运行和管理多个命令
2️⃣:作业与在sehll提示符中输入的每个管道相关联、该管道中的所有进程均是作业的一部分,并且是同一个进程组的成员
3️⃣:如果在shell提示符中仅输入了一条命令,则这条命令可视为命令的最小管道;该命令将是该作业的唯一成员
4️⃣:一次只能有一个作业从特定终端窗口读取输入和键盘生成的信号。属于该作业的进程是该控制终端的前台进程
2、作业分类
1️⃣:前台作业:通过终端启动,且启动后一直占据了命令提示符
2️⃣:后台作业:可以通过终端启动,但启动之后,释放命令提示符,后续的操作在后台完成
- 此类作业虽然被送往后台运行,但其依然与终端相关。如果希望送往后台后,剥离与终端的关系需要执行(nohup COMMAND &)
3、后台运行作业演示
//在命令后跟上&符号可以生成一个后台作业
[root@localhost ~]# sleep 1000 &
[1] 2247
[root@localhost ~]# jobs
[1]+ 运行中 sleep 1000 &
// jobs命令用于显示当前所有的后台作业
4、fg —— 将后台作业调至前台运行
[root@localhost ~]# sleep 1000 &
[1] 2284
[root@localhost ~]# jobs
[1]+ 运行中 sleep 1000 &
[root@localhost ~]# fg
sleep 1000
//光标会在这一行卡主,直到超过1000秒;
//当只有一个后台作业时,直接使用fg命令,不跟任何参数即可将后台作业调至前台运行 //当有多个后台作业时,必须加上%num(num是每个后台作业的编号,也就是[]中的数字)
[root@localhost ~]# sleep 1000 &
[1] 2313
[root@localhost ~]# sleep 1100 &
[2] 2314
[root@localhost ~]# sleep 1200 &
[3] 2316
[root@localhost ~]# jobs
[1] 运行中 sleep 1000 &
[2]- 运行中 sleep 1100 &
[3]+ 运行中 sleep 1200 &
[root@localhost ~]# ps -ef | grep sleep
root 2313 2084 0 10:40 pts/2 00:00:00 sleep 1000
root 2314 2084 0 10:40 pts/2 00:00:00 sleep 1100
root 2316 2084 0 10:40 pts/2 00:00:00 sleep 1200
root 2318 2084 0 10:41 pts/2 00:00:00 grep --color=auto sleep
// 现在我想让第二个sleep放到前台运行
[root@localhost ~]# fg %2
sleep 1100 //如果多个后台作业,不加参数,直接用fg就直接调取最后一个作业到前台运行
[root@localhost ~]# jobs
[1] 运行中 sleep 1000 &
[2]- 运行中 sleep 1100 &
[3]+ 运行中 sleep 1200 &
[root@localhost ~]# fg
sleep 1200
5、Ctrl+z —— 将前台作业放到后台运行
//使用ctrl+z可将前台进程发送到后台,此时作业将处于停止状态
[root@localhost ~]# sleep 1000 &
[1] 2345
[root@localhost ~]# jobs
[1]+ 运行中 sleep 1000 &
[root@localhost ~]# fg
sleep 1000
^Z // 此处按ctrl+z
[1]+ 已停止 sleep 1000
[root@localhost ~]# jobs
[1]+ 已停止 sleep 1000
6、bg —— 使后台已停止的作业重新运行
[root@localhost ~]# jobs
[1]+ 已停止 sleep 1000
[root@localhost ~]# bg
[1]+ sleep 1000 &
[root@localhost ~]# jobs
[1]+ 运行中 sleep 1000 & //当有多后台作业的时候,需要使用bg+%num(num是后台作业的编号,也就是[]中的数字)
[root@localhost ~]# jobs
[1] 运行中 sleep 1000 &
[2]- 已停止 sleep 1100
[3]+ 已停止 sleep 1200
[root@localhost ~]# bg %2
[2]- sleep 1100 &
[root@localhost ~]# jobs
[1] 运行中 sleep 1000 &
[2]- 运行中 sleep 1100 &
[3]+ 已停止 sleep 1200 //如果不加参数,只是使用bg,那么久从后往前逐一将后台停止的作业重新运行
[root@localhost ~]# jobs
[1] 已停止 sleep 1000
[2]- 已停止 sleep 1100
[3]+ 已停止 sleep 1200
[root@localhost ~]# bg
[3]+ sleep 1200 &
[root@localhost ~]# bg
[2]+ sleep 1100 &
[root@localhost ~]# bg
[1]+ sleep 1000 &
7、终止后台作业
//kill加上作业号可以手动杀死指定作业
[root@localhost ~]# jobs
[1] 运行中 sleep 1000 &
[2] 运行中 sleep 1100 &
[3]+ 已停止 sleep 1200
[4]- 已停止 sleep 1300
[root@localhost ~]# kill %1
[root@localhost ~]# kill %2
[root@localhost ~]# jobs
[3]+ 已停止 sleep 1200
[4]- 已停止 sleep 1300 //将后台作业放到前台,按Ctrl+c终止作业任务
[root@localhost ~]# jobs
[3]- 运行中 sleep 1200 &
[4]+ 已停止 sleep 1300
[root@localhost ~]# fg %3
sleep 1200
^C //在这按Ctrl+c
[root@localhost ~]# jobs
[4]+ 已停止 sleep 1300
[root@localhost ~]# fg %4
sleep 1300
^C //这里也是一样,按CTRL+c
[root@localhost ~]# jobs
[root@localhost ~]#
8、jobs命令的结果
- + //命令将默认操作的作业
- - //命令将第二个默认操作的作业
Linux_控制作业(管理)的更多相关文章
- python 全栈开发,Day108(客户管理之权限控制,客户管理之动态"一级"菜单,其他应用使用rbac组件,django static文件的引入方式)
一.客户管理之权限控制 昨天的作业,有很多不完善的地方 下载代码,基本实现权限验证 https://github.com/987334176/luffy_permission/archive/v1.2 ...
- Linux_用户权限管理
目录 目录 用户管理 useradd创建用户 userdel删除用户 usermod修改用户账号 passwd修改用户密码 用户权限设置 用户组管理 查看用户的属组 修改用户组gpasswd 为没有家 ...
- Linux_网络基础管理
一.网卡的命名 1.传统网卡命名 eth0.eth1.eth2.eth3......... wlan0.wlan1.waln2.wlan3......... 2.RHEL7命名机制 systemd对网 ...
- Linux_控制服务与守护进程
一.systemd 1.systemd简介 1️⃣:systemd是用户空间的第一个应用程序,即/sbin/init 2️⃣:init程序的类型: SysV风格:init(centos5),实现系统初 ...
- MVC基于角色权限控制--用户管理
用户管理模块包括 新增用户.修改用户.展示用户列表.删除用户.用户角色分配.用户角色删除.用户权限分配 这里只介绍关于权限有关的 用户角色分配.用户角色删除.用户权限分配 新建控制器 UserInfo ...
- Linux_系统时间管理
目录 目录 时间管理 date指令 系统时间设置timedatectl指令 本地时间同步 时间服务器NTP RHEL6 RHEL7 计划任务 一次性计划任务 at指令 限制用户建立一次性计划任务 周期 ...
- Linux_软件安装管理
开始学习rpm,yum等命令的使用,下面的地址可供你学习 大部分都大同小异! 感谢作者:https://segmentfault.com/a/1190000011200461
- JS-图片控制-动画管理模块
animateManage.js ;(function(window,document,undefined){ var _aniQueue = [], //动画队列 --- ani:动画,Queue: ...
- Linux_网络进阶管理
一.链路聚合 1.什么是链路聚合? 网卡的链路聚合就是将多块网卡连接起来,当-块网卡损坏,网络依旧可以正常运行,可以有效的防止因为网卡损坏带来的损失,同时也可以提高网络访问速度. 2.链路聚合方式: ...
随机推荐
- VS2019 自定义项目模板
前言: 使用"宇宙最强IDE"开发项目时,都需要根据不同情况选择一个项目模板,来满足开发需求:如下 VS为我们提供了基础的项目模板,但现有项目模板未包含基础功能如:日志输出.审计日 ...
- (6)MySQL进阶篇SQL优化(MyISAM表锁)
1.MySQL锁概述 锁是计算机协调多个进程或线程并发访问某一资源的机制.在数据库中,除传统的计算资源 (如 CPU.RAM.I/O 等)的抢占以外,数据也是一种供许多用户共享的资源.如何保证数 据并 ...
- 201871030105-陈啟程 实验三 结对项目—《D{0-1}KP 实例数据集算法实验平台》项目报告
项目 内容 课程班级博客 https://edu.cnblogs.com/campus/xbsf/2018CST 这个作业要求链接 https://www.cnblogs.com/nwnu-daizh ...
- CSS @property,让不可能变可能
本文主要讲讲 CSS 非常新的一个特性,CSS @property,它的出现,极大的增强的 CSS 的能力! 根据 MDN -- CSS Property,@property CSS at-rule ...
- 【macOS】显示/隐藏 允许“任何来源”的应用
问题产生 在macOS中安装某些版本软件时会提示: "xxx"已损坏,打不开.您应该将它移动到废纸篓. 某些情况下实际上并不是软件已损坏,而是因为macOS对于开发者的验证导致软件 ...
- babel配置文件.babelrc详解
一:理解 babel之配置文件.babelrc 基本配置项 1. 什么是babel? 它是干什么用的? ES6是2015年发布的下一代javascript语言标准,它引入了新的语法和API,使我们编写 ...
- Knight Moves UVA - 439
A friend of you is doing research on the Traveling Knight Problem (TKP) where you are to find the sh ...
- 开源Influxdb2高性能客户端
前言 最近我在了解时序数据库Influxdb 2.x版本,体验一翻之后,感觉官方的出品的.net客户端还有很多优化的地方,于是闭关几天,不吃不喝,将老夫多年练就的高性能网络通讯与高性能Buffer操作 ...
- 使用Power BI构建数据仓库与BI方案
杀手级特性 今年Power BI的几大杀手级特性的GA,可以让其构建完整的数据仓库/数据湖和BI分析一站式方案. Power BI Premium Per User-超低的价格 Large datas ...
- 1.4.19- HTML标签之注释标签
有的时候我们输入的代码,让你别人看,别人不知道你的思路,可能就看不懂,或者或一段时间自己就看不懂了,这个时候我们需要对代码进行注释,解释我们的代码什么意思: <!DOCTYPE html> ...