基础知识 数据下载 格式

Linux 命令的后台运行

2017-04-08  本文已影响0人  hyrijk

先来写一个需要一直运行的程序,比如 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 命令结束。

上一篇下一篇

猜你喜欢

热点阅读