Linux 命令的后台运行
先来写一个需要一直运行的程序,比如 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]
是任务编号,+
-
和接下来要说的 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
命令结束。