最近在写Daemon进程,在编写过程中遇到一些小麻烦,最终还是解决了。
我编写了两种,第一种是编写了一个程序,将其用setsid命令让其放入后台运行,第二种是直接fork()一个进程,在代码里将进程设置为后台启动。
在os.sytem()函数其他外部程序时,发现os.system()是阻塞的(os.popen()也是阻塞的),就是启动外部程序,你必须等外部程序退出,它才继续运行。用python中的subprocess库时,发现它并不阻塞主进程的运行,但是,你用外部kill命令杀死进程时,子进程会变成僵尸进程,只有父进程退出后才会退出。网上说在Windows平台下,python有个os.startfile是可以启动外部程序并不阻塞程序的运行,因为我写的Linux环境下,所以该函数不能用。最后问其他朋友,他说可以在system()将输出重定向就可以了,我试了一下,真的可以,所以现在把代码贴出了,也怪自己平常没有怎么钻。
os.system(processName+" 1>/dev/null 2>/dev/null &")
程序功能:
从配置文件读取要监控的进程,对进程实现监控,当监控程序退出时,会自动拉起进程
第一种方法:
在后台启动命令如下:setsid ./WatchProcessDog.py -m &
代码如下:
#!/usr/bin/python
#!encoding=utf-8
import ConfigParser
import sys
import threading
import time
import os
import commands
import subprocess
CONFIG_FILE = "WatchDog.ini"
SECTION="Monitor"
SECTION_KEY="Process"
class CWatchProcess(threading.Thread):
def __init__(self,configFile):
threading.Thread.__init__(self)
self.thread_stop = False
self.boolexist = False
self.curPid = os.getpid()
self.configFile = configFile
cfg = ConfigParser.ConfigParser()
try:
cfg.read(self.configFile)
allprocesses = cfg.get(SECTION,SECTION_KEY)
if '#' in allprocesses:
position1 = allprocesses.find('#')
self.processes = allprocesses[:position1]
else:
self.processe