LINUX任务(jobs)详解
LINUX任务(jobs)详解
在⽤管理员执⾏⼀个命令后,⽤Ctrl+Z把命令转移到了后台。导致⽆法退出root的。
输⼊命令:exit
终端显⽰:There are stopped jobs.
解决⽅法:
⽅法⼀、输⼊命令:jobs
终端显⽰:[1]+ Stopped vim /etc/network/interfaces > /home/leo/ (wd: /)
KILL %1
⽅法⼆、输⼊命令:jobs -l
终端显⽰:[1]+ 4664 停⽌ vim /etc/network/interfaces > /home/leo/ (wd: /)
看到4664,这个就是PID了
现在开始杀掉它:
输⼊命令:kill 4664
终端没有显⽰。ok。
再⽤jobs命令查看,确认已经杀掉了
Linux Jobs等前后台运⾏命令解
A,Shell⽀持作⽤控制,有以下命令:
1. command& 让进程在后台运⾏
2. jobs 查看后台运⾏的进程
3. fg %n 让后台运⾏的进程n到前台来
4. bg %n 让进程n到后台去;
PS:"n"为jobs查看到的进程编号.
fg、bg、jobs、&、ctrl + z都是跟系统任务有关的,虽然现在基本上不怎么需要⽤到这些命令,但学会了也是很实⽤的
⼀。& 最经常被⽤到
这个⽤在⼀个命令的最后,可以把这个命令放到后台执⾏
⼆。ctrl + z
可以将⼀个正在前台执⾏的命令放到后台,并且暂停
三。jobs
查看当前有多少在后台运⾏的命令
四。fg
将后台中的命令调⾄前台继续运⾏
如果后台中有多个命令,可以⽤ fg %jobnumber将选中的命令调出,%jobnumber是通过jobs命令查到的后台正在执⾏的命令的序号(不是pid)
五。bg
将⼀个在后台暂停的命令,变成继续执⾏
如果后台中有多个命令,可以⽤bg %jobnumber将选中的命令调出,%jobnumber是通过jobs命令查到的后台正在执⾏的命令的序号(不是pid)
#Linux下使⽤Shell命令控制任务Jobs执⾏
下列命令可以⽤来操纵进程任务:
ps 列出系统中正在运⾏的进程;
kill 发送信号给⼀个或多个进程(经常⽤来杀死⼀个进程);
jobs 列出当前shell环境中已启动的任务状态,若未指定jobsid,则显⽰所有活动的任务状态信息;如果报告了⼀个任务的终⽌(即任务的状态被标记为Terminated),shell 从当前的shell环境已知的列表中删除任务的进程标识;
bg 将进程搬到后台运⾏(Background);
fg 将进程搬到前台运⾏(Foreground);
将job转移到后台运⾏
如果你经常在X图形下⼯作,你可能有这样的经历:通过终端命令运⾏⼀个GUI程序,GUI界⾯出来了,但是你的终端还停留在原地,你不能在shell中继续执⾏其他命令了,除⾮将GUI程序关掉。
为了使程序执⾏后终端还能继续接受命令,你可以将进程移到后台运⾏,使⽤如下命令运⾏程序: #假设要运⾏xmms
$xmms &
这样打开xmms后,终端的提⽰⼜回来了。现在xmms在后台运⾏着呢;但万⼀你运⾏程序时忘记使⽤“&”了,⼜不想重新执⾏;你可以先使⽤ctrl+z挂起程序,然后敲⼊bg命令,这样程序就在后台继续运⾏了。
概念:当前任务
如果后台的任务号有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,这是由内核来终⽌进程,进程不能监听这个信号。
linux执行shell命令===================
Unix/Linux下⼀般想让某个程序在后台运⾏,很多都是使⽤ & 在程序结尾来让程序⾃动运⾏。⽐如我们要运⾏mysql在后台:
/usr/local/mysql/bin/mysqld_safe --user=mysql &
 但是我们很多程序并不象mysqld⼀样可以做成守护进程,可能我们的程序只是普通程序⽽已,⼀般这种程序即使使⽤ & 结尾,如果终端关闭,那么程序也会被关闭。为了能够后台运⾏,我们需要使⽤nohup这个命令,⽐如我们有个start.sh需要在后台运⾏,并且希望在后台能够⼀直运⾏,那么就使⽤nohup:
nohup /root/start.sh &
在shell中回车后提⽰:
[~]$ appending output to nohup.out
原程序的的标准输出被⾃动改向到当前⽬录下的nohup.out⽂件,起到了log的作⽤。
但是有时候在这⼀步会有问题,当把终端关闭后,进程会⾃动被关闭,察看nohup.out可以看到在关闭终端瞬间服务⾃动关闭。
咨询红旗Linux⼯程师后,他也不得其解,在我的终端上执⾏后,他启动的进程竟然在关闭终端后依然运⾏。
在第⼆遍给我演⽰时,我才发现我和他操作终端时的⼀个细节不同:他是在当shell中提⽰了nohup成功后还需要按终端上键盘任意键退回到shell输⼊命令窗⼝,然后通过在shell中输⼊exit来退出终端;⽽我是每次在nohup执⾏成功后直接点关闭程序按钮关闭终端.。所以这时候
会断掉该命令所对应的session,导致nohup对应的进程被通知需要⼀起shutdown。
这个细节有⼈和我⼀样没注意到,所以在这⼉记录⼀下了。
附:nohup命令参考
nohup 命令
  ⽤途:不挂断地运⾏命令。
  语法:nohup Command [ Arg ... ] [ & ]
  描述:nohup 命令运⾏由 Command 参数和任何相关的 Arg 参数指定的命令,忽略所有挂断(SIGHUP)信号。在注销后使⽤ nohup 命令运⾏后台中的程序。要运⾏后台中的 nohup 命令,添加 & (表⽰"and"的符号)到命令的尾部。
  ⽆论是否将 nohup 命令的输出重定向到终端,输出都将附加到当前⽬录的 nohup.out ⽂件中。如果当前⽬录的 nohup.out ⽂件不可写,输出重定向到 $HOME/nohup.out ⽂件中。如果没有⽂件能创建或打开以⽤于追加,那么 Command 参数指定的命令不可调⽤。如果标准错误是⼀个终端,那么把指定的命令写给标准错误的所有输出作为标准输出重定向到相同的⽂件描述符。
  退出状态:该命令返回下列出⼝值:
  126 可以查但不能调⽤ Command 参数指定的命令。
  127 nohup 命令发⽣错误或不能查由 Command 参数指定的命令。
  否则,nohup 命令的退出状态是 Command 参数指定命令的退出状态。
  nohup命令及其输出⽂件
  nohup命令:如果你正在运⾏⼀个进程,⽽且你觉得在退出帐户时该进程还不会结束,那么可以使⽤nohup命令。该命令可以在你退出帐户/关闭终端之后继续运⾏相应的进程。nohup就是不挂起的意思( n ohang up)。
  该命令的⼀般形式为:nohup command &
  使⽤nohup命令提交作业
  如果使⽤nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到⼀个名为nohup.out的⽂件中,除⾮另外指定了输出⽂件:
  nohup command > myout.file 2>&1 &
  在上⾯的例⼦中,输出被重定向到myout.file⽂件中。
  使⽤ jobs 查看任务。
  使⽤ fg %n 关闭。
  另外有两个常⽤的ftp⼯具ncftpget和ncftpput,可以实现后台的ftp上传和下载,这样就可以利⽤这些命令在后台上传和下载⽂件了。
简单⽽有⽤的nohup命令在UNIX/LINUX中,普通进程⽤&符号放到后台运⾏,如果启动该程序的控制台logout,则该进程随即终⽌。
  要实现守护进程,⼀种⽅法是按守护进程的规则去编程(本站有⽂章介绍过),⽐较⿇烦;另⼀种⽅法是仍然⽤普通⽅法编程,然后⽤nohup命令启动程序:
  nohup<程序名>&
  则控制台logout后,进程仍然继续运⾏,起到守护进程的作⽤(虽然它不是严格意义上的守护进程)。
  使⽤nohup命令后,原程序的的标准输出被⾃动改向到当前⽬录下的nohup.out⽂件,起到了log的作⽤,实现了完整的守护进程功能。  ygwu @ 2005年04⽉18⽇上午10:03
  For example:
  如何远程启动WebLogic服务?
  ⽤telnet远程控制服务器,远程启动WEBLOGIC服务,启动后关闭telnet,WebLogic服务也跟着停⽌,这是因为使⽤telnet启动的进程会随着telnet进程的关闭⽽关闭。所以我们可以使⽤⼀些UNIX下的命令来做到不关闭。
  使⽤如下命令:
  nohup startWeblogic.sh&
  如果想要监控标准输出可以使⽤:
  tail -f nohup.out
  当在后台运⾏了程序的时候,可以⽤jobs命令来查看后台作业的状态。在有多个后台程序时,要使⽤来参数的fg命令将不同序号的后台作业切换到前台上运⾏。
  当⽤户启动⼀个进程的时候,这个进程是运⾏在前台,使⽤与相应控制终端相联系的标准输⼊、输出进⾏输⼊和输出。即使将进程的输⼊输出重定向,并将进程放在后台执⾏,进程仍然和当前终端设备有关系。正因为如此,在当前的登录会话结束时,控制终端设备将和登录进程相脱离,那么系统就向所有与这个终端相联系的进程发送SIGHUP的信号,通知进程线路已经挂起了,如果程序没有接管这个信号的处理,那么缺省的反应是进程结束。因此普通的程序并不能真正脱离登录会话⽽运⾏进程,为了使得
在系统登录后还可以正常执⾏,只有使⽤命令nohup来启动相应程序。
  使⽤命令nohup当然可以启动这样的程序,但nohup启动的程序在进程执⾏完毕就退出,⽽常见的⼀些服务进程通常永久的运⾏在后台,不向屏幕输出结果。在Unix中这些永久的后台进程称为守护进程(daemon)。守护进程通常从系统启动时⾃动开始执⾏,系统关闭时才停⽌。
  在守护进程中,最重要的⼀个是超级守护进程inetd,这个进程接管了⼤部分⽹络服务,但并不是对每个服务都⾃⼰进⾏处理,⽽是依据连接请求,启动不同的服务程序与客户机打交道。inetd⽀持⽹络服务种类在它的设置⽂件/f中定义。f⽂件中的每⼀⾏就对应⼀个端⼝地址,当inetd接受到连接这个端⼝的连接请求时,就启动相应的进程进⾏处理。使⽤inetd的好处是系统不必启动很多守护进程,从⽽节约了系统资源,然⽽使⽤inetd启动守护进程相应反应会迟缓⼀些,不适合⽤于被密集访问的服务进程。