zoukankan      html  css  js  c++  java
  • linux 命令后台执行

    我想把updatedb命令(用于重新建立整盘索引的命令)放在后台运行。因为我不想眼睁睁的看着机器建立索引,我还想编会儿程序呢:

    # updatedb &

    [1] 23336

    注释:在所要执行的命令后面加上空格,再加上&符号即可实现后台执行。所返回的[1]表示这是第一个你放到后台的任务(2表示第二个)。23336是这个任务的进程号

    2 我执行updatedb时忘了加&了,这下我怎么办?有办法:

    按键盘上的ctrl-z组合键,可以将前台任务扔到后台!但务必注意的是,用ctrl-z的话,这个任务到了后台可是stopped的状态。(你都无情的把它ctrl-z到后台了,它怎么可能还会任劳任怨的继续在后台工作呢?)

    3 我学会了这招,我把很多程序都放到后台执行了。我想查看一下:

    # jobs (显示任务状态)

    [1]+  Running                 updatedb &

    注释:显示出了正在后台运行的任务的列表

    4 我编程结束了。想把刚才的updatedb放回前台看看。

    # fg %1

    注释:fg中的f就表示front,ground前台的意思。%1表示是在jobs命令中列出的1号任务。如果是2号任务呢,我猜你知道如何写。

    (fg:

    fg: fg [任务声明]
    将任务移至前台。

    将以 JOB_SPEC 标识的任务放至前台,使其成为
    当前任务。如果 JOB_SPEC 不存在,shell 观念中的当前任务
    将被使用。

    退出状态:
    放至前台的命令状态,或者当错误发生时为失败。)

    5 如果你用jobs命令发现有一个显示[stopped]的任务(任务号是2),我想让这个任务继续在后台执行:

    # bg %2

    注释:stopped的状态通常出现在用户ctrl-z之后。

    6 我想让后台的任务号是3的任务取消:

    # kill %3

    注释:这样就杀死了任务号为3的后台任务。

    参考:

    http://roclinux.cn/?p=161

    另一篇:

    在Linux中,当在前台运行某个作业时,终端被该作业占据;而在后台运行作业时,它不会占据终端。可以使用&命令把作业放到后台执行。实际上,这样是将命令放入到一个作业队列中了:

    $ ./test.sh &
    [1] 17208

    $ jobs -l
    [1]+ 17208 Running                 ./test.sh &
        在后台运行作业时要当心:需要用户交互的命令不要放在后台执行,因为这样你的机器就会在那里傻等。不过,作业在后台运行一样会将结果输出到屏幕上,干扰你的工作。如果放在后台运行的作业会产生大量的输出,最好使用下面的方法把它的输出重定向到某个文件中:
    command >out.file 2>&1 &
    在上面的例子中,2>&1表示所有的标准输出和错误输出都将被重定向到一个叫做out.file 的文件中。 当你成功地提交进程以后,就会显示出一个进程号,可以用它来监控该进程,或杀死它。 
    例:查找名为“httpd.conf”的文件,并把所有标准输出和错误输出重定向到find.dt的文件中: 
    # find /etc/httpd/ -name "httpd.conf" -print >find.dt 2>&1 & 
    [2] 7832 
    成功提交该命令之后,系统给出了它的进程号7832。 对于已经在前台执行的命令,也可以重新放到后台执行,首先按ctrl+z暂停已经运行的进程,然后使用bg命令将停止的作业放到后台运行,例如对正在前台执行的tesh.sh使用ctrl+z挂起它:
    $ ./test.sh
    [1]+ Stopped                 ./test.sh

    $ bg %1
    [1]+ ./test.sh &

    $ jobs -l
    [1]+ 22794 Running                 ./test.sh &

    但是如上方到后台执行的进程,其父进程还是当前终端shell的进程,而一旦父进程退出,则会发送hangup信号给所有子进程,子进程收到hangup以后也会退出。如果我们要在退出shell的时候继续运行进程,则需要使用nohup忽略hangup信号,或者setsid将将父进程设为init进程(进程号为1)

    $ echo $$
    21734

    $ nohup ./test.sh &
    [1] 29016

    $ ps -ef | grep test
    515      29710 21734 0 11:47 pts/12   00:00:00 /bin/sh ./test.sh
    515      29713 21734 0 11:47 pts/12   00:00:00 grep test
    $ setsid ./test.sh &
    [1] 409

    $ ps -ef | grep test
    515        410     1 0 11:49 ?        00:00:00 /bin/sh ./test.sh
    515        413 21734 0 11:49 pts/12   00:00:00 grep test
    上面的试验演示了使用nohup/setsid加上&使进程在后台运行,同时不受当前shell退出的影响。那么对于已经在后台运行的进程,该怎么办呢?可以使用disown命令:

    $ ./test.sh &
    [1] 2539

    $ jobs -l
    [1]+ 2539 Running                 ./test.sh &

    $ disown -h %1

    $ ps -ef | grep test
    515        410     1 0 11:49 ?        00:00:00 /bin/sh ./test.sh
    515       2542 21734 0 11:52 pts/12   00:00:00 grep test
    另外还有一种方法,即使将进程在一个subshell中执行,其实这和setsid异曲同工。方法很简单,将命令用括号() 括起来即可:

    $ (./test.sh &)

    $ ps -ef | grep test
    515        410     1 0 11:49 ?        00:00:00 /bin/sh ./test.sh
    515      12483 21734 0 11:59 pts/12   00:00:00 grep test
    注:本文试验环境为Red Hat Enterprise Linux AS release 4 (Nahant Update 5),shell为/bin/bash,不同的OS和shell可能命令有些不一样。例如AIX的ksh,没有disown,但是可以使用nohup -p PID来获得disown同样的效果。

    还有一种更加强大的方式是使用screen,首先创建一个断开模式的虚拟终端,然后用-r选项重新连接这个虚拟终端,在其中执行的任何命令,都能达到nohup的效果,这在有多个命令需要在后台连续执行的时候比较方便:

    $ screen -dmS screen_test

    $ screen -list
    There is a screen on:
            27963.screen_test       (Detached)
    1 Socket in /tmp/uscreens/S-jiangfeng.

    $ screen -r screen_test

    三、 nohup 
        如果你正在运行一个进程,而且你觉得在退出帐户时该进程还不会结束,那么可以使用nohup命令。该命令可以在你退出帐户之后继续运行相应的进程。nohup就是不挂起的意思( no hang up)。 该命令的一般形式为: 
    nohup conmmand &
    如果使用nohup命令提交作业,那么在缺省情况下该作业的所有输出都被重定向到一个名为nohup.out的文件中,除非另外指定了输出文件:
    nohup command > myout.file 2>&1 
    在上面的例子中,输出被重定向到myout.file文件中。


    四、.*,?,[...],[!...]等 
    下面就是这些特殊字符: 
    * 匹配文件名中的任何字符串,包括空字符串。 
    ? 匹配文件名中的任何单个字符。 
    [...] 匹配[ ]中所包含的任何字符。 
    [!...] 匹配[ ]中非感叹号!之后的字符。 
    当s h e l l遇到上述字符时,就会把它们当作特殊字符,而不是文件名中的普通字符,这样用户就可以用它们来匹配相应的文件名。

    1)列出以i或o开头的文件名:     #ls [io]*
    2)列出log.开头、后面跟随一个数字、然后可以是任意字符串的文件名: #ls log.[0-9]* 
    3)与例二相反,列出log.开头、后面不跟随一个数字、然后可以是任意字符串的文件名 : #ls log.[!0-9]* 
    4)列出所有以LPS开头、中间可以是任何两个字符,最后以1结尾的文件名:#ls LPS??1
    5)列出所有以大写字母开头的文件名:$ ls [A-Z]* 6)列出所有以. 开头的文件名(隐含文件,例如. profile、.rhosts、.histo ry等): $ ls .*

    • 其他相关命令:

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

    • 杀死进程

    杀死已经启动的程序和普通方式一样:

    • pkill -9 name
    • killall name
    • kill pid
  • 相关阅读:
    html调用applet
    WindowListener中的windowClosed方法不执行的问题。
    有理数类 Java BigInteger实现
    有理数类 Java
    BigInteger构造函数解析
    求最大公约数(辗转相除法)
    Java 十六进制转十进制
    Java 十进制转十六进制
    ORA-12520: TNS:listener could not find available handler for requested type of server
    关于 error: Operation is not valid due to the current state of the object。
  • 原文地址:https://www.cnblogs.com/youxin/p/3553169.html
Copyright © 2011-2022 走看看