目的: 针对Windows下进程异常退出后,此程序自动启动被监控进程。如:监控Serv-U.exe 程序是使用python语言编写,可在Windows下双击MonitorWin32Process.exe直接运行。程序会按照config.ini配置文件,进行监控进程。如果没有被监控的进程,则会按照进程启动路径自动启动。 详细使用请查看压包内的使用说明.
1.. 环境配置 2.. 使用说明 3.. 待改进 4.. 下载链接
5.. 发邮件通知功能源码. 1.. 环境配置
需要的安装包python、wmi 介绍wmi 网站
http://tgolden.sc.sabren.com/python/wmi/index.html#what-is-it
xp 安装WMI
Windows installer: http://timgolden.me.uk/python/downloads/WMI-1.4.6.win32.exe
win7 将安装包解压到python lib 目录下,详细查看readme文件。
Zipped-up source: http://timgolden.me.uk/python/downloads/WMI-1.4.6.zip
环境配置可能遇到的问题
C:\Python27\Lib\WMI-1.4.6>python setup.py install
Traceback (most recent call last):
File "setup.py", line 2, in <module>
import wmi
File "C:\Python27\Lib\WMI-1.4.6\wmi.py", line 88, in <module>
from win32com.client import GetObject, Dispatch
ImportError: No module named win32com.client
解决方法:
相应python版本的win32扩展,安装后问题即解决。网址如下:
http://sourceforge.net/projects/pywin32/files/
程序代码
#!-*- encoding: utf-8 -*-
import logging
import wmi
import os
import time
from ConfigParser import ConfigParser
CONFIGFILE='./config.ini'
config = ConfigParser()
config.read(CONFIGFILE)
ProgramPath = config.get('MonitorProgramPath','ProgramPath')
ProcessName = config.get('MonitorProcessName','ProcessName')
c = wmi.WMI()
def main():
ProList = [] #如果在main()函数之外ProList 不会清空列表内容.
for process in c.Win32_Process():
ProList.append(str(process.Name))
if ProcessName in ProList:
print "Service " + ProcessName + " is running...!!!"
if os.path.isdir("c:\MonitorWin32Process"):
pass
else:
os.makedirs("c:\MonitorWin32Process")
else:
print "Service " + ProcessName + " error ...!!!"
os.startfile(ProgramPath)
if __name__ == "__main__":
while True:
main()
time.sleep(300)
1..2 将py程序编译成windows下可执行文件
py2exe下载地址,找到与安装的Python 版本相同的py2exe版本.
http://sourceforge.net/projects/py2exe/files/py2exe/0.6.9/
from distutils.core import setup
import py2exe
setup(console=['MonitorWin32Process.py'],
)
问题描述: 当执行C:\Documents and Settings\Administrator\Desktop\temp>python setup.py py2exe 执行一段代码后出现 弹出一个窗口提示Python.exe 程序将要结束的 解决方法 : 这是因为setup.py中 logo.ico图片是由原来的gif 直接修改后缀名为ico 造成的.
from distutils.core import setup
import py2exe
setup(
console = [{"script" : "MonitorWin32Process.py", "icon_resources" : [(1, "logo.ico")]}]
)
注: 将以上 console 修改windowns 在windowns下的可执行程序,将不会出现cmd窗口.
2.. 使用说明 2..1 必须先配置config.ini 配置压缩包中config.ini文件,修改服务启动的路径和进程在任务管理器中的名字.
[MonitorProgramPath]
ProgramPath: C:\Program Files\RhinoSoft.com\Serv-U\Serv-U.exe
[MonitorProcessName]
ProcessName: Serv-U.exe
如:
[MonitorProgramPath]
ProgramPath: C:\Program Files\Tencent\QQ\Bin\QQ.exe
[MonitorProcessName]
ProcessName: QQ.exe
2..2 将MonitorWin32Process.exe拖到启动中. 即可开机启动. 3.. 待改进
3..1 出现错误时在屏幕上一闪马上消失了.
应添加下面红色代码,这样有利于排查错误.
if ProcessName in ProList:
print "Service " + ProcessName + " is running...!!!"
if os.path.isdir("c:\MonitorWin32Process"):
pass
else:
os.makedirs("c:\MonitorWin32Process")
else:
print "Service " + ProcessName + " error ...!!!"
os.startfile(ProgramPath)
time.sleep(5)
3..2 应该加上日志功能.
按天或按月进行分日志.
4.. 下载链接
http://down.51cto.com/data/381581
5. 发邮件通知功能源码.
#!-*- encoding: utf-8 -*-
import wmi,os,time,smtplib
from ConfigParser import ConfigParser
from email.mime.text import MIMEText
#### 发送邮件 代码开始
#####################
#获取smtp服务器,用户名、口令、邮箱的后缀、收件人列表
CONFIGFILE="./config.ini"
config = ConfigParser()
config.read(CONFIGFILE)
mailHost = config.get('mailHost','Host')
mailUser = config.get('mailUser','User')
mailPass = config.get('mailPass','Pass')
mailPostfix = config.get('mailPostfix','Postfix')
mailToList = config.get('mailToList','toList')
#获取主题
subject = config.get('subject','subject')
######################
def send_mail(mailToList,sub,content):
'''
to_list:发给谁
sub:主题
content:内容
'''
RealTime = time.strftime("%Y-%m-%d %X",time.localtime())
content = RealTime + " " + content
me="Monitor"+"<"+mailUser+"@"+mailPostfix+">"
msg = MIMEText(content,'plain','gb2312')
msg['Subject'] = sub
msg['From'] = me
msg['To'] = mailToList
try:
s = smtplib.SMTP()
s.connect(mailHost)
s.login(mailUser,mailPass)
s.sendmail(me, mailToList, msg.as_string())
s.close()
return True
except Exception, e:
print str(e)
return False
#### 发送邮件 代码结束
dirName = "d:\MonitorWin32Process\\"
logSuffix = ".log"
logErrorSuffix = ".error.log"
config = ConfigParser()
config.read(CONFIGFILE)
ProgramPath = config.get('MonitorProgramPath','ProgramPath')
ProcessName = config.get('MonitorProcessName','ProcessName')
SleepTime = config.get('ProcessSleepTime','SleepTime')
if not os.path.isdir(dirName):
os.makedirs(dirName)
c = wmi.WMI()
def main():
ProList = [] #如果在main()函数之外ProList 不会清空列表内容.
timetimeDay = time.strftime("%Y-%m-%d",time.localtime())
timetimeLog = time.strftime("%Y-%m-%d %X",time.localtime())
logFileName = dirName + timeDay + logSuffix
logFileNameError = dirName + timeDay + logErrorSuffix
if not os.path.isfile(logFileName):
file(logFileName,'a')
for process in c.Win32_Process():
ProList.append(str(process.Name))
if ProcessName in ProList:
content = timeLog + " Service " + ProcessName + " is running...!!!\n"
logFile = open(logFileName,'a+')
logFile.write(content)
logFile.close()
else:
content = timeLog + " Service " + ProcessName + " is error !!!" + "\n"
logFile = open(logFileNameError,'a+')
logFile.write(content)
logFile.close()
os.startfile(ProgramPath)
send_mail(mailToList,subject,content)
if __name__ == "__main__":
while True:
main()
time.sleep(int(SleepTime))