windows下python监控系统服务
来源:互联网 发布:linux查找软件命令 编辑:程序博客网 时间:2024/06/03 18:43
原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://future.blog.51cto.com/26959/831816
- http://tgolden.sc.sabren.com/python/wmi/index.html#what-is-it
- Windows installer: http://timgolden.me.uk/python/downloads/WMI-1.4.6.win32.exe
- 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 造成的.
当执行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")]}]
- )
- [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)
- http://down.51cto.com/data/381581
- #!-*- 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))
0 0
- windows下python监控系统服务
- Python对Windows服务进行监控
- Python制作Windows系统服务
- Python制作Windows系统服务
- Python实现Windows监控agent(下)
- Python监控Windows下的文件变化
- [分布式跨平台监控系统]linux,windows下一句话发邮件-python 脚本应用
- 用C#开发Windows服务监控系统使用
- 用C#开发Windows服务监控系统使用
- 用C#开发Windows服务监控系统使用
- 用C#开发Windows服务监控系统使用
- 用C#开发Windows服务监控系统使用
- 用C#开发Windows服务监控系统使用
- Python WMI获取Windows系统信息 监控系统
- C# 监控Windows服务
- 系统服务监控命令
- windows 2003 下删除系统服务
- Windows下配置Tomcat为系统服务
- 切换到MarkDown编辑器
- perf Examples
- Spark aggregator ExternalIterator 流程图
- java实现栈结构解析
- 关于thinkphp中的验证码生成与刷新
- windows下python监控系统服务
- hdoj Phone List 1671 (字典树记录前缀)
- HDFS 简介
- shuoj-小6爱夜跑--Floyd记录多个最短路径
- 获取验证码函数
- 抽象数据类型
- App Nap
- 先验概率与后验概率及贝叶斯公式
- <Neural Networks_Tricks of the Trade> Chapter 1 Efficient BackProp (1)