必发365官网 1

必发365官网LINUX 暂停、继续进程

   
在Linux系统中,作业是由一个或多个关联进程组成的。用户可以运行多个作业并可以在作业间切换。而作业控制则是对作业的行为进行控制,允许用户对作业的前后台的进行切换和终止操作等。作业相关的控制命令如下所示:

LINUX 暂停、继续进程

kill -STOP 1234 将该进程暂停。

如果要让它恢复到后台,用kill -CONT
1234
 (很多在前台运行的程序这样是不行的)

如果要恢复到前台,请在当时运行该进程的那个终端用jobs命令查询暂停的进程。

然后用 fg 〔job号〕把进程恢复到前台。

 

如果jobs只查询到一个进程,只用 fg 即可。

例:

root@dWorks:~# bc -q

 

[1]+  Stopped                 bc -q

root@dWorks:~# bc -q

 

[2]+  Stopped                 bc -q

root@dWorks:~# jobs

[1]-  Stopped                 bc -q

[2]+  Stopped                 bc -q

root@dWorks:~# fg 2

bc -q

1+1

2

 

A,Shell支持作用控制,有以下命令:

  1. command& 让进程在后台运行

  2. jobs 查看后台运行的进程

  3. fg %n 让后台运行的进程n到前台来

  4. bg %n 让进程n到后台去;  

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

 

B.下列转:http://blog.chinaunix.net/u/1604/showart\_1079559.html

 

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

一。& 最经常被用到

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

二。ctrl + z

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

三。jobs

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

四。fg

将后台中的命令调至前台继续运行

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

五。bg

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

必发365官网,如果后台中有多个命令,可以用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,这是由内核来终止进程,进程不能监听这个信号。

===================

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)。守护进程通常从系统启动时自动开始执行,系统关闭时才停止。

  • 后台符号(&):让作业在后台运行
  • 快捷键Ctrl+Z:让作业切换到后台并停止运行
  • 命令jobs:显示作业列表
  • 命令fg:将作业切换到前台并运行
  • 命令bg:将作业切换到后台并运行
  • 命令kill:终止作业

   
当用户在终端中启动一个作业时,它会默认在前台运行。前台作业的特点就是从标准输入接收用户指令并通过标准输出将返回信息展示给用户。
   
后台作业则脱离了标准输入和标准输出,并不需要用户参与,默默在用户看不到的地方运行。类似于Windows中多窗口界面,选中一个窗口则自动激活窗口并切换到前台运行,而其他窗口则自动转入后台运行。

后台符号 &

    后台符号则是指 ** &
**,使用起来也非常简单,只需要把该符号放置在执行命令的后面即可。通过在执行一个命令需要花费较长的时间或执行命令后就不再需要用户输入命令等操作时使用,示例如下:

[root@localhost ~]# sleep 20m &
[1] 12925
  • 后台符号与前面的命令之间需要添加空格
  • [1]表示后台作业任务的编号
  • 12925表示后台作业对应的PID

如通过管道技术,作业由一组命令组成,此时返回的PID是最后一个命令程序所对应的PID

快捷键Ctrl+Z

   
如果在执行命令的忘记输入后台符号时,此时我们可以使用快捷键Ctrl+Z,将前台作业切换到后台。而该作业在切换到后台也自动会停止运行,示例如下:

[root@localhost ~]# top -d 3
top - 23:09:05 up 1 day,  8:56,  1 user,  load average: 0.41, 0.48, 0.68
KiB Mem :13174040+total,91322784 free,34024536 used,6393076 buff/cache
KiB Swap: 4194300 total, 4194300 free, 0 used. 96571448 avail Mem

PID  USER   PR  NI VIRT   RES   SHR   S  %CPU %MEM TIME+    COMMAND
2325 mysql  20  0  20.7g 383068 12780 S  23.5 0.3  47:02.72 mysqld
1873 cinder 20  0 476152 103060 8900  S  5.9  0.1  40:59.23 cinder-backup
# 使用Ctrl+Z可以看到作业已经转入后台并停止运行
[3]+  已停止               top -d 3

显示作业列表jobs

基本用法

jobs [选项] [jobID]

其常用选项如下所示:

选项 说明
-l 显示PID
-p 仅显示作业的PID
-r 仅显示运行状态的作业
-s 仅显示停止状态的作业

jobs示例

1、显示所有作业

[root@localhost ~]# jobs
[2]-  已停止               top -d 3
[3]+  已停止               top -d 3
[4]   运行中               sleep 20m &

2、显示作业的ID

[root@localhost ~]# jobs -p
5442
14740
39178

3、仅显示停止状态的作业

[root@localhost ~]# jobs -s
[2]-  已停止               top -d 3
[3]+  已停止               top -d 3

fg

   fg全称frontground,是指将作业切换到前台并运行。

基本用法

fg [作业标识]

fg示例

1、将后台作业转换到前台并运行

[root@localhost ~]# jobs
[3]+  已停止               top -d 3
[4]   运行中               sleep 20m &
[6]   运行中               sleep 120m &
[7]-  运行中               sleep 10h &
[root@localhost ~]# fg %3
top - 23:09:05 up 1 day,  8:56,  1 user,  load average: 0.41, 0.48, 0.68
KiB Mem :13174040+total,91322784 free,34024536 used,6393076 buff/cache
KiB Swap: 4194300 total, 4194300 free, 0 used. 96571448 avail Mem

PID  USER   PR  NI VIRT   RES   SHR   S  %CPU %MEM TIME+    COMMAND
2325 mysql  20  0  20.7g 383068 12780 S  23.5 0.3  47:02.72 mysqld
1873 cinder 20  0 476152 103060 8900  S  5.9  0.1  40:59.23 cinder-backup

bg

    bg全称background,是指的主要作用是将作业切换到后台并运行。

基本用法

bg [作业标识]

bg示例

1、将作业转换到后台并运行

[root@localhost ~]# jobs
[2]-  已停止               top -d 3
[3]   已停止               top -d 3
[4]   运行中               sleep 20m &
[5]   运行中               sleep 120s &
[6]+  已停止               sleep 120m
[root@localhost ~]# bg %6
[6]+ sleep 120m &
[root@localhost ~]# jobs
[2]+  已停止               top -d 3
[3]   已停止               top -d 3
[4]   运行中               sleep 20m &
[5]   运行中               sleep 120s &
[6]-  运行中               sleep 120m &

终止作业

    要想终止作业,则需要使用kill命令即,其常用法如下所示:

kill [jobID]

示例如下所示:

[root@localhost ~]# jobs
[3]+  已停止               top -d 3
[6]   运行中               sleep 120m &
[7]-  运行中               sleep 10h &
[root@localhost ~]# kill %7
[7]-  已终止               sleep 10h
[root@localhost ~]# jobs
[3]+  已停止               top -d 3
[6]-  运行中               sleep 120m &

作业名字

   
在上面的示例,使用的是%n表示形式来指定一个作业任务,除这种方法外,还有其他更多的方式来指定作业任务,详细如下所示:

表示形式 解释 示例
%number Number必须为正整数,指根据编号确定job fg %1
%string 匹配命令行以string开头的作业,如果匹配到多个则报错 kill %sleep
%?string 匹配命令行含有string的作业,如果是通过管道连接的多个命令,则仅匹配第一个命令 bg %?sleep
%% 匹配在作业列表中最近一个被切换到后台的作业 kill %%
%+ 同%% kill %+
%- 匹配在%%所指定的作业前面的作业 kill %-

示例

1、%string的用法

[root@localhost ~]# jobs
[3]-  已停止               top -d 3
[6]   运行中               sleep 120m &
[7]+  已停止               sleep 120h
[root@localhost ~]# kill %top
[root@localhost ~]# jobs
[6]-  运行中               sleep 120m &
[7]+  已停止               sleep 120h

2、%%用法

[root@localhost ~]# jobs
[6]-  运行中               sleep 120m &
[7]+  已停止               sleep 120h
# 作业编号后面的+/-分别对应 %+ 和 %-
[root@localhost ~]# bg %7
[7]+ sleep 120h &
[root@localhost ~]# jobs
[6]-  运行中               sleep 120m &
[7]+  运行中               sleep 120h &
[root@localhost ~]# kill %%
[7]+  已终止               sleep 120h
[root@localhost ~]# jobs
[6]+  运行中               sleep 120m &

nohup

   
终端是我们进入Linux系统的入口,无论是排查问题、执行操作面对的都是Linux终端。当用户进行注销、断开网络时,终端均会收到SIGHUP(hangup)信号,然后关闭其所属的子进程,而如果我们不希望某些进程被这个SIGHUP信号影响,就需要使用命令nohup
    nohup英文解释如下:

run a command immune to hangups, with output to a non-tty

在使用nohup命令后,程序是对SIGHUP免疫的,不受影响的。而nohup与 &
的区别如下

  • 后台符号(&):只是暂时让进程运行于终端后台,而SIGHUP仍然影响到这些后台的进程
  • nohup:在将进程运行于终端后台并不受SIGHUP影响。

基本用法

nohup [命令] &
  • 如果终端是标准输入,则从/dev/null进行重定向
  • 如果终端是标准输出,则输出重定向于当前目录中nohup.out文件,否则则重定向到$HOME/nohup.out
  • 如果终端是标准错误输出,则重定向于标准输出
  • 如果要保存输出到文件,可以使用nohup [命令] > path/FILE

示例用法

# 将命令设置为后台运行
[root@localhost ~]# nohup ping www.baiduc.com &
[1] 36247
# 因未指定输出重定向,默认将标准输出、标准错误输出都追加至nohup.out
[root@localhost ~]# nohup: 忽略输入并把输出追加到"nohup.out"
[root@localhost ~]# jobs
[1]+  运行中               nohup ping www.baiduc.com &
# 重定向至家目录中
[root@localhost ~]# nohup ping www.baidu.com > ~/pingTest.txt &
[1] 12588
# 虽指定重定向文件,但未指定标准错误输出重定向文件,因此会出现以下警告
[root@localhost ~]# nohup: 忽略输入重定向错误到标准输出端
[root@localhost ~]# nohup ping www.baidu.com > ~/pingTest.txt 2>&1  &
[3] 34498
  • ~/pingTest.txt:表示将标准输出(1)重定向于文件pingTest.txt中

  • 2>&1:表示将标准错误输出(2)重定向到标准输出(1),因些可将标准输出和标准错误输出均重定向到文件pingTest.txt中

  • 如果不需要保存标准错误输出和标准输出,则可以重定向于/dev/null

本文同步在微信订阅号上发布,如各位小伙伴们喜欢我的文章,也可以关注我的微信订阅号:woaitest,或扫描下面的二维码添加关注:
必发365官网 1