一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

腳本之家,腳本語言編程技術及教程分享平臺!
分類導航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服務器之家 - 腳本之家 - Python - Python使用Supervisor來管理進程的方法

Python使用Supervisor來管理進程的方法

2020-07-09 08:29imzoer Python

這篇文章主要介紹了Python使用Supervisor來管理進程的方法,涉及Supervisor的相關使用技巧,需要的朋友可以參考下

本文實例講述了Python使用Supervisor來管理進程的方法。分享給大家供大家參考。具體分析如下:

Supervisor可以啟動、停止、重啟*nix系統(tǒng)中的程序。也可以重啟崩潰的程序。

supervisord的一個守護進程,用于將指定的進程當做子進程來運行。

supervisorctl是一個客戶端程序,可以查看日志并通過統(tǒng)一的會話來控制進程。

看例子:

我們寫了一個py腳本,用于往log文件中記錄一條當前的時間。

?
1
2
3
4
5
6
7
8
9
10
root@ubuntu:/home/zoer# cat daemon.py
#!/usr/bin/env python
import time
import os
time.sleep(1)
f=open("log",'a')
t=time.time()
f.write(str(t))
f.write("\n")
f.close()

安裝過程就不說了。

安裝完畢supervisor之后【將配置文件放在/etc下】。修改配置文件,在最后增加如下內容:

[program:ddd]
command=/home/zoer/daemon.py
autorestart=true

然后我們啟動supervisor并啟動daemon.py的執(zhí)行。

?
1
2
3
4
5
6
7
8
9
10
11
12
root@ubuntu:/home/zoer# supervisord
/usr/local/lib/python2.7/dist-packages/supervisor-3.0b1-py2.7.egg/supervisor/options.py:286: UserWarning: Supervisord is running as root and it is searching for its configuration file in default locations (including its current working directory); you probably want to specify a "-c" argument specifying an absolute path to a configuration file for improved security.
 'Supervisord is running as root and it is searching '
root@ubuntu:/home/zoer# supervisorctl
ddd               STARTING  
supervisor> start ddd
ddd: ERROR (already started)
supervisor> stop ddd
ddd: stopped
supervisor> start ddd
ddd: started
supervisor>

從上面的例子中,看到,可以通過start或者stop命令來啟動或者停止ddd這個進程。ddd這里就是我們在配置文件中增加的內容(daemon.py這個腳本)。

也可以使用restart。如下:

supervisor> restart  ddd
ddd: stopped
ddd: started

下面我們測試一下,假設說我們手動kill掉了ddd這個進程,那么ddd會自動恢復執(zhí)行嗎?

為了做實驗,把代碼修改如下:

?
1
2
3
4
5
6
7
8
9
10
11
root@ubuntu:/home/zoer# cat daemon.py 
#!/usr/bin/env python
import time
import os
while True:
  time.sleep(1)
  f=open("log",'a')
  t=time.time()
  f.write(str(t))
  f.write("\n")
  f.close()

通過ps可以找到這個進程的id:

?
1
2
3
root   9354 0.2 0.4 10924 4200 ?    S  23:16  0:00 python /home/zoer/daemon.py
root   9395 0.0 0.0  4392  832 pts/3  S+  23:17  0:00 grep --color=auto daemon
root@ubuntu:/home/zoer#

看下面的操作:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
root@ubuntu:/home/zoer# rm log;touch log;kill 9354
root@ubuntu:/home/zoer# cat log
1364710712.51
root@ubuntu:/home/zoer# cat log
1364710712.51
1364710713.51
root@ubuntu:/home/zoer# cat log
1364710712.51
1364710713.51
root@ubuntu:/home/zoer# cat log
1364710712.51
1364710713.51
1364710714.52
root@ubuntu:/home/zoer# cat log
1364710712.51
1364710713.51
1364710714.52
1364710715.52

刪除了log文件,并且重新創(chuàng)建。然后干掉了daemon.py的那個進程。會發(fā)現(xiàn)log內容又重新有新的內容了。再次ps查看進程號。

?
1
2
3
root   9429 0.1 0.4 10924 4200 ?    S  23:18  0:00 python /home/zoer/daemon.py
root   9440 0.0 0.0  4392  828 pts/3  S+  23:19  0:00 grep --color=auto daemon
root@ubuntu:/home/zoer#

會發(fā)現(xiàn)進程號已經(jīng)變成9429了。說明supervisor已經(jīng)重啟了被干掉了的進程。

希望本文所述對大家的Python程序設計有所幫助。

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 1024亚洲天堂 | 美女一级ba大片免色 | 午夜伦伦电影理论片大片 | 黄 在线播放 | 国产一二三区视频 | 四虎精品成人a在线观看 | 国产亚洲欧美一区二区三区 | 国产成人综合网亚洲欧美在线 | 精品成人网 | 啊啊啊好大好爽视频 | 午夜在线观看免费观看 视频 | 饭冈加奈子黑人解禁在线播放 | 国产男技师 | 欧美特级午夜一区二区三区 | 亚洲精品动漫在线观看 | 大学生特黄特色大片免费播放 | 欧美国产日产精品免费视频 | 天天射寡妇射 | 日本女人www | 欧美精选视频 | 99午夜 | 情欲满载2012美国dvd | 亚洲高清成人 | 娇妻与公陈峰姚瑶小说在线阅读 | 国产成+人+亚洲+欧美综合 | 污文啊好棒棒啊好了 | 亚洲成年人专区 | 男人j放进女人的p视频免费 | 爽爽窝窝午夜精品一区二区 | 欧美成人免费观看国产 | 国产偷窥女洗浴在线观看亚洲 | futa百合文| 免费看成年视频网页 | 亚洲va久久久噜噜噜久久狠狠 | 成人免费片 | 精品久久一区 | 免费看成人毛片日本久久 | 91精品国产色综合久久 | 天天快乐在线观看 | 俄罗斯性高清完整版 | 欧美成人精品福利在线视频 |