激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

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

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系統中的程序。也可以重啟崩潰的程序。

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

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

看例子:

我們寫了一個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的執行。

?
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會自動恢復執行嗎?

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

?
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文件,并且重新創建。然后干掉了daemon.py的那個進程。會發現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#

會發現進程號已經變成9429了。說明supervisor已經重啟了被干掉了的進程。

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

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 国产一级毛片国产 | 日韩精品中文字幕一区二区三区 | 最新国产毛片 | 国产91久久精品一区二区 | 亚洲欧美国产高清va在线播放 | 久久免费视频在线 | 日韩av电影在线免费观看 | 精品中文字幕在线播放 | av电影在线网站 | 日本在线视频免费观看 | 久久久久久久91 | 久久综合综合 | 九九热视频这里只有精品 | 一级视频片 | 精品一区二区三区免费 | 毛片网站网址 | 国产精品一区在线观看 | 少妇的肉体2无删减版 | 99久久婷婷国产综合精品青牛牛 | 久久综合久久美利坚合众国 | 免费三级大片 | 国产一区日韩精品 | 一级毛片在线观看免费 | 国产精品一区二区三区在线播放 | 一本视频在线观看 | 精品呦女 | 欧美精品一区自拍a毛片在线视频 | www.成人在线视频 | 伊人yinren22综合网色 | 婷婷一区二区三区四区 | 久久人人爽人人爽人人片av高清 | 护士hd欧美free性xxxx | 狠狠一区 | 日日夜av| 欧美在线成人影院 | xnxx 日本19| 午夜色片 | 成人福利视频 | 亚洲va久久久噜噜噜久久男同 | 国产在线欧美 | 中文字幕在线网站 |