jobs简介

jobs简介

    jobs可以显示当前shell 环境中已启动的作业状态。

    用linux的时候经常会碰到类似这种情形,复制,下载一个很大的文件或编辑一个文件,任务占据着界面不能做其他操作,这个时候想不暂停或中止任务去做别的操作就可以将正在执行的命令送往后台去运行。


作业:作业号

    # jobs

作业控制命令:

    # fg [[%]JOBNUM] :将制定命令调回前台

    # bg [[%]JOBNUM] :让送往后台的作业在后台继续运行

    # kill %JOBNUM :终止制定的作业

            fg,bg的时候:%可以省略

            kill %JOBNUM :%不可省略

       PS:"n"为jobs查看到的进程编号.

fg、bg、jobs、&、ctrl + z都是跟系统任务有关的,虽然现在基本上不怎么需要用到这些命令,但学会了也是很实用的

& :这个用在一个命令的最后,可以把这个命令放到后台执行

ctrl + z:可以将一个正在前台执行的命令放到后台,并且暂停

jobs:查看当前有多少在后台运行的命令

             如果 JobID 参数没有指定特定作业,就显示所有的活动的作业的状态信息。如果报告了一个作业的终止,shell 从当前的 shell 环境已知的列表中删除作业的进程标识。

fg:将后台中的命令调至前台继续运行
            如果后台中有多个命令,可以用 fg %jobnumber将选中的命令调出,%jobnumber是通过jobs命令查到的后台正在执行的命令的序号(不是pid)


bg:将一个在后台暂停的命令,变成继续执行

    如果后台中有多个命令,可以用bg %jobnumber将选中的命令调出,%jobnumber是通过jobs命令查到的后台正在执行的命令的序号(不是pid)


细节,讲解

概念:当前任务 

  如果后台的任务号有2个,[1],[2];如果当第一个后台任务顺利执行完毕,第二个后台任务还在执行中时,当前任务便会自动变成后台任务号码“[2]”的后台任务。所以可以得出一点,即当前任务是会变动的。当用户输入“fg”、“bg”和“stop”等命令时,如果不加任何引号,则所变动的均是当前任务。

察看jobs 
  使用jobs或ps命令可以察看正在执行的jobs。 

  jobs命令执行的结果,+表示是一个当前的作业,减号表是是一个当前作业之后的一个作业,jobs -l选项可显示所有任务的PID,jobs的状态可以是running, stopped, Terminated,但是如果任务被终止了(kill),shell 从当前的shell环境已知的列表中删除任务的进程标识;也就是说,jobs命令显示的是当前shell环境中所起的后台正在运行或者被挂起的任务信息;

进程的挂起 

  后台进程的挂起: 

  在solaris中通过stop命令执行,通过jobs命令查看job号(假设为num),然后执行stop %num;

  在redhat中,不存在stop命令,可通过执行命令kill -stop PID,将进程挂起;

  当要重新执行当前被挂起的任务时,通过bg %num 即可将挂起的job的状态由stopped改为running,仍在后台执行;当需要改为在前台执行时,执行命令fg %num即可;

前台进程的挂起:

  ctrl+Z;

进程的终止 

       后台进程的终止:
          方法一:

              通过jobs命令查看job号(假设为num),然后执行kill %num

          方法二:

              通过ps命令查看job的进程号(PID,假设为pid),然后执行kill pid 

      前台进程的终止:

          ctrl+c



扩展知识:

kill的其他作用 
  kill除了可以终止进程,还能给进程发送其它信号,使用kill -l 可以察看kill支持的信号。 

  SIGTERM是不带参数时kill发送的信号,意思是要进程终止运行,但执行与否还得看进程是否支持。如果进程还没有终止,可以使用kill -SIGKILL pid,这是由内核来终止进程,进程不能监听这个信号。

关闭终端,此终端的后台job继续运行

    按照上面的方法在当前终端运行的命令将他们调到后台去后,如果关闭了终端这些后台的jobs都会关闭。假如我们登陆到服务器下载一个东西,下载的很慢,下班时间到了,总不能不关掉电脑回家吧,这个时候介绍一个新命令

    nohup,

    nohup /root/start.sh & 

    在shell中回车后提示:

    [~]$ appending output to nohup.out

   原程序的的标准输出被自动改向到当前目录下的nohup.out文件,起到了log的作用。

    关于nohup的详细使用,可以查看我以后的博客。

原创文章,作者:瓶云,如若转载,请注明出处:http://www.178linux.com/4707

(0)
瓶云瓶云
上一篇 2015-05-23 22:21
下一篇 2015-05-25 20:52

相关推荐

  • 如何恢复误删除的rpm包命令

    如何恢复误删除的rpm包命令 在linux学习过程中,我们会遇到各种各样的问题,当然,如果能够将遇到的问题一一解决也是非常开心的,因为在解决问题的过程中我们的专业技能也得到了很大的提升。最近的测试中遇到了一个平时很少接触的问题:如何恢复误删除的rpm包命令。所以觉得有必要写下来,以防止下次出现类似的问题而不会解决。 首先模拟卸载rpm rpm -e &#82…

    2017-08-26
  • 第五周作业

    1、显示当前系统上root,fedora或user1用户的默认shell。 [root@hostname ~]# grep -E ‘^(root|fedora|user1)’ /etc/passwd | cut -d: -f1,7 root:/bin/bash 2、找出/etc/rc.d/init.d/functions文件中某词后面跟一组小括号的行,形如:…

    Linux干货 2017-08-04
  • Centos 系列bind搭建DNS服务加固

        在centos系列版本上运用bind搭建dns服务教程已经有很多,先感谢前人做出的贡献,引用两篇博文,讲解的非常详细。 地址是: 主dns搭建:http://blog.csdn.net/reblue520/article/details/52537014 从dns搭建:http://blog.csdn.net/reblue520/…

    Linux干货 2017-04-16
  • 自建CA搭建SSL加密网站

    企业环境中,在安全级别要求较高的公司,经常需要搭建基于SSL加密传输的网站,使用https协议访问web站点,能大大提高网站的安全性。但构建https站点,需要用到证书。内部网站到互联网上申请费用不菲的证书显然不符合经济性。于是,自建内部CA成为我们的首选。 本文以两台服务器,分别扮演CA及Web网站的角色,详细论述自建CA搭建加密网站的过程。  …

    Linux干货 2016-07-29
  • linux中扩展swap分区和移动设备使用挂载以及常用的工具free、df 、du、dd命令

    swap分区 swap分区作用:内存不足时充当系统内存,所以swap尽量放在告诉硬盘上也就是尽量使用磁盘的第一个分区 动手创建swap分区       1、创建分区,将分区类型转换成swap分区格式           &nbsp…

    Linux干货 2016-08-29