先来写一个需要一直运行的程序,比如 Flask 版的 Hello World
$ vi hello.py
from flask import Flask
app = Flask(__name__)
@app.route('/')
def index():
return '
hello world
'
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] 是任务编号,+ - 和接下来要说的 fg、bg 命令有关,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 将后台运行的程序调到前台
fg 和 bg 命令一样,可以直接打 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 命令结束。