Python编写Windows Service服务程序


Posted in Python onJanuary 04, 2018

 如果你想用Python开发Windows程序,并让其开机启动等,就必须写成windows的服务程序Windows Service,用Python来做这个事情必须要借助第三方模块pywin32,自己去下载然后安装(注意下载符合自己OS的版本)。

1.示例分析

1).幸运的是这里有一个简单的服务模版,足以满足大多数人的要求:

#encoding=utf-8 
#ZPF 
import win32serviceutil 
import win32service 
import win32event 
 
class PythonService(win32serviceutil.ServiceFramework): 
 #服务名 
 _svc_name_ = "PythonService" 
 #服务在windows系统中显示的名称 
 _svc_display_name_ = "Python Service Test" 
 #服务的描述 
 _svc_description_ = "This code is a Python service Test" 
 
 def __init__(self, args): 
  win32serviceutil.ServiceFramework.__init__(self, args) 
  self.hWaitStop = win32event.CreateEvent(None, 0, 0, None) 
 
 def SvcDoRun(self): 
  # 把自己的代码放到这里,就OK 
  # 等待服务被停止 
  win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE) 
    
 def SvcStop(self): 
  # 先告诉SCM停止这个过程 
  self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING) 
  # 设置事件 
  win32event.SetEvent(self.hWaitStop) 
 
if __name__=='__main__': 
 win32serviceutil.HandleCommandLine(PythonService) 
 #括号里参数可以改成其他名字,但是必须与class类名一致;

2).解释一下这段代码:在类PythonService的__init__函数执行完后,系统服务开始启动,windows系统会自动调用SvcDoRun函数,这个函数的执行不可以结束,因为结束就代表服务停止。所以当我们放自己的代码在SvcDoRun函数中执行的时候,必须确保该函数不退出,如果退出或者该函数没有正常运行就表示服务停止,windows系统会提示:

Python编写Windows Service服务程序

3).当停止服务的时候,系统会调用SvcDoStop函数,该函数通过设置标志位等方式让SvcDoRun函数退出,就是正常的停止服务。例子中是通过event事件让SvcDoRun函数停止等待,从而退出该函数,从而使服务停止。

4).注意:系统关机时不会调用SvcDoStop函数,所以这种服务是可以设置为开机自启的。

2.实例

一般都是通过在SvcDoRun函数中设置循环来达到不退出的目的,看例子通过设置标志位run来实现:

#ZPF 
#encoding=utf-8 
import win32serviceutil 
import win32service 
import win32event 
import os 
import logging 
import inspect 
 
class PythonService(win32serviceutil.ServiceFramework): 
 
 _svc_name_ = "PythonService" 
 _svc_display_name_ = "Python Service Test" 
 _svc_description_ = "This is a python service test code " 
 
 def __init__(self, args): 
  win32serviceutil.ServiceFramework.__init__(self, args) 
  self.hWaitStop = win32event.CreateEvent(None, 0, 0, None) 
  self.logger = self._getLogger() 
  self.run = True 
   
 def _getLogger(self): 
   
  logger = logging.getLogger('[PythonService]') 
   
  this_file = inspect.getfile(inspect.currentframe()) 
  dirpath = os.path.abspath(os.path.dirname(this_file)) 
  handler = logging.FileHandler(os.path.join(dirpath, "service.log")) 
   
  formatter = logging.Formatter('%(asctime)s %(name)-12s %(levelname)-8s %(message)s') 
  handler.setFormatter(formatter) 
   
  logger.addHandler(handler) 
  logger.setLevel(logging.INFO) 
   
  return logger 
 
 def SvcDoRun(self): 
  import time 
  self.logger.info("service is run....") 
  while self.run: 
   self.logger.info("I am runing....") 
   time.sleep(2) 
    
 def SvcStop(self): 
  self.logger.info("service is stop....") 
  self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING) 
  win32event.SetEvent(self.hWaitStop) 
  self.run = False 
 
if __name__=='__main__': 
 win32serviceutil.HandleCommandLine(PythonService)

4.服务操作命令

下面是对上述服务操作的基本命令:

1.安装服务   

python PythonService.py install

2.让服务自动启动   

python PythonService.py --startup auto install

3.启动服务  

python PythonService.py start

4.重启服务

python PythonService.py restart

5.停止服务   

python PythonService.py stop

6.删除/卸载服务   

python PythonService.py remove

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
在Django的模型和公用函数中使用惰性翻译对象
Jul 27 Python
Python3使用requests包抓取并保存网页源码的方法
Mar 15 Python
Python爬虫实例_城市公交网络站点数据的爬取方法
Jan 10 Python
flask-socketio实现WebSocket的方法
Jul 31 Python
python使用xlrd和xlwt读写Excel文件的实例代码
Sep 05 Python
使用django-guardian实现django-admin的行级权限控制的方法
Oct 30 Python
python中的tcp示例详解
Dec 09 Python
python 判断字符串中是否含有汉字或非汉字的实例
Jul 15 Python
pytorch 图像中的数据预处理和批标准化实例
Jan 15 Python
python使用OpenCV模块实现图像的融合示例代码
Apr 10 Python
PyTorch中torch.tensor与torch.Tensor的区别详解
May 18 Python
对Keras中predict()方法和predict_classes()方法的区别说明
Jun 09 Python
微信跳一跳python辅助软件思路及图像识别源码解析
Jan 04 #Python
Python操作MongoDB数据库的方法示例
Jan 04 #Python
Python字典操作详细介绍及字典内建方法分享
Jan 04 #Python
Python tkinter实现的图片移动碰撞动画效果【附源码下载】
Jan 04 #Python
Python给你的头像加上圣诞帽
Jan 04 #Python
Python编程实现线性回归和批量梯度下降法代码实例
Jan 04 #Python
Python语言描述随机梯度下降法
Jan 04 #Python
You might like
利用ThinkPHP内置的ThinkAjax实现异步传输技术的实现方法
2011/12/19 PHP
基于ubuntu下nginx+php+mysql安装配置的具体操作步骤
2013/04/28 PHP
php三元运算符知识汇总
2015/07/02 PHP
SAE实时日志接口SDK用法示例
2016/10/09 PHP
浅析PHP反序列化中过滤函数使用不当导致的对象注入问题
2020/02/15 PHP
用javascript自动显示最后更新时间
2007/03/15 Javascript
JS维吉尼亚密码算法实现代码
2010/11/09 Javascript
下载文件个别浏览器文件名乱码解决办法
2013/03/19 Javascript
Jquery的Tabs内容轮换效果实现代码,几行搞定
2014/02/12 Javascript
js实现按钮加背景图片常用方法
2014/11/01 Javascript
Bootstrap字体图标无法正常显示的解决方法
2016/10/08 Javascript
学习使用bootstrap的modal和carousel
2016/12/09 Javascript
利用select实现年月日三级联动的日期选择效果【推荐】
2016/12/13 Javascript
Node.js和Express简单入门介绍
2017/03/24 Javascript
利用JavaScript的%做隔行换色的实例
2017/11/25 Javascript
详解AngularJS之$window窗口对象
2018/01/17 Javascript
浅谈webpack打包生成的bundle.js文件过大的问题
2018/02/22 Javascript
Vue利用canvas实现移动端手写板的方法
2018/05/03 Javascript
使用layui的router来进行传参的实现方法
2019/09/06 Javascript
超简单的微信小程序轮播图
2019/11/22 Javascript
Vue初始化中的选项合并之initInternalComponent详解
2020/06/11 Javascript
[50:28]2018DOTA2亚洲邀请赛 3.31 小组赛 A组 Newbee vs KG
2018/04/01 DOTA
对python实现合并两个排序链表的方法详解
2019/01/23 Python
Python机器学习算法库scikit-learn学习之决策树实现方法详解
2019/07/04 Python
Python concurrent.futures模块使用实例
2019/12/24 Python
Pyside2中嵌入Matplotlib的绘图的实现
2021/02/22 Python
Speedo速比涛德国官方网站:世界领先的泳装品牌
2019/08/26 全球购物
英国领先的男装设计师服装独立零售商:Repertoire Fashion
2020/10/19 全球购物
学习群众路线的心得体会
2014/11/05 职场文书
出国导师推荐信
2015/03/25 职场文书
幼儿园端午节活动总结
2015/05/05 职场文书
2015年幼儿园教育教学工作总结
2015/05/25 职场文书
借钱欠条怎么写
2015/07/03 职场文书
高中班主任工作总结(范文)
2019/08/20 职场文书
Nginx 反向代理解决跨域问题多种情况分析
2022/01/18 Servers
python中validators库的使用方法详解
2022/09/23 Python