Linux 命令的后台运行

作者: hyrijk | 来源:发表于2017-04-08 15:50 被阅读0次

    先来写一个需要一直运行的程序,比如 Flask 版的 Hello World

    $ vi hello.py
    
    from flask import Flask
    
    app = Flask(__name__)
    
    @app.route('/')
    def index():
        return '<h1>hello world<h1>'
    
    if __name__ == '__main__':
        app.run(host='0.0.0.0')
    
    $ pip install flask
    $ python hello.py
    

    启动成功控制台提示:

    * Running on http://0.0.0.0:5000/ (Press CTRL+C to quit)
    

    此时打开浏览器访问 http://你的服务器ip:5000 即可看到 Hello World

    CTRL+C 退出,如果想让程序一直运行又想同时做其他事怎么办?

    CTRL+Z 暂停程序

    程序在前台运行时,按下 CRTL+Z, 程序进入暂停状态

    [1]  + 74237 suspended  python hello.py
    

    此时你又可以在终端下敲其他命令了。但刷新浏览器,长时间没有响应,因为程序进入暂停状态了。

    jobs 列出后台运行的命令

    $ jobs
    [1]  - suspended  python hello.py
    

    再来启动一个命令,比如

    $ tail -f hello.py
    

    然后 CTRL+Z 暂停,再运行下 jobs 命令

    $ jobs
    [1]  - suspended  python hello.py
    [2]  + suspended  tail -f hello.py
    

    前面的[1] [2] 是任务编号,+ - 和接下来要说的 fgbg 命令有关,suspended 那一栏表示状态,剩下的就是命令了

    bg 将程序运行在后台

    直接打 bg 命令不加参数,运行的将是 jobs 列出的 第二列是 + 的那个程序

    $ jobs
    [1]  - suspended  python hello.py
    [2]  + suspended  tail -f hello.py
    $ bg
    [2]  - 74616 continued  tail -f hello.py
    $ jobs
    [1]  + suspended  python hello.py
    [2]  - running    tail -f hello.py
    

    打了一次 bg 命令之后,原本是 + 的那个命令变成 running 了,同时 + 也移到了其他命令前面

    $ bg
    [1]  - 74237 continued  python hello.py
    $ jobs
    [1]  - running    python hello.py
    [2]  + running    tail -f hello.py
    

    此时看到 python hello.py 处于运行状态,浏览器访问 http://你的服务器ip:5000 正常看到 hello world,但尽管程序已经在后台运行了,终端还是有日志输出:

    127.0.0.1 - - [08/Apr/2017 14:34:52] "GET / HTTP/1.1" 200 -
    

    这对我们的其他工作造成了干扰,下面再讨论怎么解决这个问题。

    bg 命令还可以添加参数任务

    $ bg %1
    

    % 号后面跟着的是 jobs 命令输出的标号

    fg 将后台运行的程序调到前台

    fgbg 命令一样,可以直接打 fg 将前面有 + 号的程序调到前台,也可以以 %标号的形式指定哪个程序

    $ fg %2
    

    然后 CTRL+C 退出,或者 CTRL+Z 暂停,然后 bg %2 在后台运行

    使用 & 将程序放到后台

    要把一个程序放在后台运行,照上面的做法,得先运行,然后 CTRL+Z 暂停,再用 bg 命令放到后台运行。使用 & 来简化这一过程,并且使用 > 来重定向后台运行的程序在终端上的输出。要继续下面的操作,先用 fg 命令将

    python hello.py
    

    调到前台,然后 CTRL+C 退出运行。

    重新运行

    $ python hello.py > hello.log 2>&1 &
    

    上面这条命令,> hello.log 表示将 python hello.py 在屏幕上标准的输出重定向到了 hello.log 这个文件,2>&1 表示将错误信息重定向到标准输出,& 号表示在后台运行。刷新浏览器,正常看到 'hello word',终端没有输出。可以使用 tail 命令加上 -f 参数追踪 hello.log 文件的输出

    $ tail -f hello.log
    

    多刷新几次浏览器,可以看到和之前那样的日志输出。
    要退出运行,同样可以使用 fg 命令,然后 CTRL+C 退出。

    nohup 命令的使用

    使用 bg 命令和 & 后台运行程序还有个缺点,你退出当前终端,程序也结束了。解决这一办法的是使用 nohup 命令,例如

    $ nohup python hello.py &
    

    nohup 命令默认将输出重定向到 nohup.out 这个文件,可以使用 tail 命令跟踪 nohup.out 这个文件观察程序的输出

    $ tail -f nohup.out
    

    多刷新几次浏览器,可以看到和之前屏幕上一样的输出。退出当前终端,刷新浏览器,还是能看到 'hello world'。
    没退出终端之前,可以使用 fg 命令将程序调到前台,然后 CTRL+C 结束。如果已经退出当前终端,下次再登录进来,可以使用 ps aux 命令找出程序的 pid, 然后用 kill 命令结束。

    相关文章

      网友评论

        本文标题:Linux 命令的后台运行

        本文链接:https://www.haomeiwen.com/subject/xlwlattx.html