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

相关推荐

  • HDFS写入和读取流程

    一、HDFS HDFS全称是Hadoop Distributed System。HDFS是为以流的方式存取大文件而设计的。适用于几百MB,GB以及TB,并写一次读多次的场合。而对于低延时数据访问、大量小文件、同时写和任意的文件修改,则并不是十分适合。 目前HDFS支持的使用接口除了Java的还有,Thrift、C、FUSE、WebDAV、HTTP等。HDFS…

    Linux干货 2015-05-12
  • linux文件权限练习(0803)

    1、当用户xiaoming对/testdir 目录无执行权限时,意味着无法做哪些操作?     不能cd到该目录,不能ls -l查看目录下文件的详细信息      2、当用户xiaoqiang对/testdir 目录无读权限时,意味着无法做哪些操作?…

    Linux干货 2016-08-04
  • 关于tar命令的一些方法

    tar 解压缩文件时只有当文件格式中有tar才能使用,否则使用其他单独的特定解压缩工具,例如uncompress,gzip ,bzip2.xz等等 tar压缩解压缩命令详解 tar命令详解 -c: 建立压缩档案 -x:解压 -t:查看内容 -r:向压缩归档文件末尾追加文件 -u:更新原压缩包中的文件 这五个是独立的命令,压缩解压都要用到其中一个,可以和别的命…

    Linux干货 2016-08-29
  • 马哥教育21期网络班—第二周课程+练习

    目录管理类命令: mkdir, rmdir, tree mkdir mkdir [options] /path/to/somewhere -p: 存在于不报错,且可自动创建所需的各目录; -v: 显示详细信息 -m MODE: 创建目录时直接指定权限; tree tree:  需要安装  yum -y install …

    Linux干货 2016-06-29
  • 第三周-作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。     ~]# who | cut -d" " -f1 | uniq 2、取出最后登录到当前系统的用户的相关信息。     ~]# who |  t…

    Linux干货 2016-12-14
  • LVM逻辑卷扩展与缩小

    逻辑卷扩容:扩展逻辑卷前一定要卸载设备和挂载点的关联 第一步:把逻辑卷lv扩展至300M 第二步:检查硬盘,并重置硬盘容量 第三步:重新挂载,查看挂载状态   缩小逻辑卷:对逻辑卷缩容时,丢失数据的风险更大。在执行操作前一定要提前备份好数据。在进行缩减前先把文件系统卸载掉。 第一步:检查文件 第二步:把逻辑卷lv减小到100M 第三步:重新挂载并查…

    2017-12-17