一、&
加在一个命令的最后,可以把这个命令放到后台执行,如:
[root@bqh-01 ~]# watch -n 3 "sh 1.sh " #每3s在后台执行一次 1.sh 脚本
二、ctrl + z
可以将一个正在前台执行的命令放到后台,并且处于暂停状态。
三、jobs
查看当前有多少在后台运行的命令
jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated。但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识。
将后台中的命令调至 前台 继续运行。如果后台中有多个命令,可以用fg %jobnumber(是命令编号,不是进程号)将选中的命令调出。
五、bg
将一个在后台暂停的命令,变成在 后台 继续执行。如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出。
六、kill
****
前台进程的终止:Ctrl+c
****七、 nohup
如果让程序始终在后台执行,即使关闭当前的终端也执行(之前的&做不到),这时候需要nohup。该命令可以在你退出帐户/关闭终端之后继续运行相应的进程。关闭中断后,在另一个终端jobs已经无法看到后台跑得程序了,此时利用ps(进程查看命令)
<pre style="margin: 0pxpadding: 0pxcolor: rgb(51, 51, 51)font-size: 14pxfont-style: normalfont-variant-ligatures: normalfont-variant-caps: normalfont-weight: 400letter-spacing: normalorphans: 2text-align: starttext-indent: 0pxtext-transform: nonewidows: 2word-spacing: 0px-webkit-text-stroke-width: 0pxbackground-color: rgb(255, 255, 255)text-decoration-style: initialtext-decoration-color: initial">ps -aux | grep "1.sh" #a:显示所有程序 u:以用户为主的格式来显示 x:显示所有程序,不以终端机来区分</pre>
当集群之间使用scp拷贝大容量文件时,往往需要将其放入后台进行运行,但scp需要输入用户密码,因此我们可以将scp进程暂停后放入后台运行,具体步骤如下:
1、scp big_file xxx@xx.xx.xx.xx:~
2、ctrl+z键 (暂停终端命令窗口正在运行的进程)
3、bg %1 (将暂停的进程放入后台运行)
4、jobs (查看后台运行的进程)
ps:
bg命令基本格式为 bg %工作号(可通过jobs命令查看暂停和后台运行的进程工作号)
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)