脚本之家,脚本语言编程技术及教程分享平台!
分类导航

Python|VBS|Ruby|Lua|perl|VBA|Golang|PowerShell|Erlang|autoit|Dos|bat|

服务器之家 - 脚本之家 - Python - Python编写Windows Service服务程序

Python编写Windows Service服务程序

2020-12-31 00:45此男子打手枪 Python

这篇文章主要为大家详细介绍了Python编写Windows Service服务程序,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

1.示例分析

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
#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来实现:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#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.安装服务   

?
1
python PythonService.py install

2.让服务自动启动   

?
1
python PythonService.py --startup auto install

3.启动服务  

?
1
python PythonService.py start

4.重启服务

?
1
python PythonService.py restart

5.停止服务   

?
1
python PythonService.py stop

6.删除/卸载服务   

?
1
python PythonService.py remove

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持服务器之家。

原文链接:http://blog.csdn.net/kmust20093211/article/details/42169323

延伸 · 阅读

精彩推荐