使用python pywin32模块创建windows服务实例探究

 更新时间:2024年01月07日 15:03:51   作者:hyang0 生有可恋  
这篇文章主要为大家介绍了使用python pywin32模块创建windows服务实现实例探究,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

pywin32 模块

在 Windows 上,Python 没有内置的守护进程(daemon)模块。但是你可以使用 pywin32 模块来实现类似的功能。先安装 pywin32 模块,然后使用 pywin32 模块调用 windows 服务 API 创建一个后台服务。

最终效果是在 services.msc 中会多出一个自定义的服务:

安装

在给出示例代码前要先安装 pywin32 模块:

C:\> pip install pywin32

同时我们还会用到 psutil 获取进程 ID,需要安装 psutil 模块:

C:\> pip install psutil

先将进程的PID写入到指定的文件中

以下代码实现了一个后台进程,它会先将进程的PID写入到指定的文件中,然后启动一个死循环,每5秒打印一条消息代表进程还存活着。

#!python3
# Filename: pyservices.py
import win32serviceutil
import win32service
import win32event
import servicemanager
import socket
import sys
import time
import psutil
def write_process_id_to_file(file_path):
    pid = str(psutil.Process().pid)
    with open(file_path, 'w') as file:
        file.write(pid)
# 进程ID
process_id_file_path = r"d:\MyPythonService.pid"
class MyService(win32serviceutil.ServiceFramework):
    _svc_name_ = "MyPythonService"
    _svc_display_name_ = "My Python Service"
    def __init__(self, args):
        win32serviceutil.ServiceFramework.__init__(self, args)
        self.hWaitStop = win32event.CreateEvent(None, 0, 0, None)
        socket.setdefaulttimeout(60)
        self.is_alive = True
    def SvcStop(self):
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        win32event.SetEvent(self.hWaitStop)
        self.is_alive = False
    def SvcDoRun(self):
        servicemanager.LogMsg(servicemanager.EVENTLOG_INFORMATION_TYPE,
                              servicemanager.PYS_SERVICE_STARTED,
                              (self._svc_name_, ''))
        self.main()
    def main(self):
        write_process_id_to_file(process_id_file_path)
        while self.is_alive:
            # 在这里编写你的守护进程主要逻辑
            print("Daemon is running...")
            time.sleep(5)
if __name__ == '__main__':
    if len(sys.argv) == 1:
        servicemanager.Initialize()
        servicemanager.PrepareToHostSingle(MyService)
        servicemanager.StartServiceCtrlDispatcher()
    else:
        win32serviceutil.HandleCommandLine(MyService)

以管理员身份运行 cmd,在命令行安装当前服务:

d:\> python pyservices.py install
Installing service MyPythonService
copying host exe 'C:\Users\Administrator\AppData\Local\Programs\Python\Python311\Lib\site-packages\win32\pythonservice.exe' -> 'C:\Users\Administrator\AppData\Local\Programs\Python\Python311\pythonservice.exe'
copying helper dll 'C:\Users\Administrator\AppData\Local\Programs\Python\Python311\Lib\site-packages\pywin32_system32\pywintypes311.dll' -> 'C:\Users\Administrator\AppData\Local\Programs\Python\Python311\pywintypes311.dll'
Service installed

services.msc查看MyPythonService

安装完后即可在 services.msc 中查看到 MyPythonService 已经注册到系统服务中了。

此时可以在服务面板中对服务进行启停,也可以在命令行中对注册的服务进行启停:

C:\> net stop MyPythonService
My Python Service 服务正在停止..
My Python Service 服务已成功停止。

C:\> net start MyPythonService
My Python Service 服务正在启动 .
My Python Service 服务已经启动成功。

同时,我们也可以在刚才的脚本执行位置对注册的服务进行启停:

d:\> python pyservices.py start
Starting service MyPythonService

d:\> python pyservices.py stop
Stopping service MyPythonService

d:\> python pyservices.py restart
Restarting service MyPythonService

除了启停服务之外,我们还能能 debug 方式运行服务。当以 debug 方式运行时,服务不会以后台方式运行,并且可以通过 ctrl+c 结束程序:

d:\> python pyservices.py debug
Debugging service MyPythonService - press Ctrl+C to stop.
Info 0x40001002 - The MyPythonService service has started.
Daemon is running...
Daemon is running...
Daemon is running...

当代码有更新时可以通过 update 命令更新服务:

d:\> python pyservices.py update
Changing service configuration
copying host exe 'C:\Users\Administrator\AppData\Local\Programs\Python\Python311\Lib\site-packages\win32\pythonservice.exe' -> 'C:\Users\Administrator\AppData\Local\Programs\Python\Python311\pythonservice.exe'
Service updated

当不再需要运行此服务时,可以注销掉服务:

d:\> python pyservices.py remove
Removing service MyPythonService
Service removed

以上就是使用python pywin32模块创建windows服务实例探究的详细内容,更多关于python创建windows服务的资料请关注脚本之家其它相关文章!

相关文章

  • python getopt详解及简单实例

    python getopt详解及简单实例

    这篇文章主要介绍了 python getopt详解及简单实例的相关资料,需要的朋友可以参考下
    2016-12-12
  • 解决导入django_filters不成功问题No module named ''django_filter''

    解决导入django_filters不成功问题No module named ''django_filter''

    这篇文章主要介绍了解决导入django_filters不成功问题No module named 'django_filter',具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • python实现selenium网络爬虫的方法小结

    python实现selenium网络爬虫的方法小结

    这篇文章主要介绍了python实现selenium网络爬虫的方法小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-03-03
  • Python利用shutil实现拷贝文件功能

    Python利用shutil实现拷贝文件功能

    shutil 是一个 Python 内置模块,该模块对文件的复制、删除和压缩等操作都提供了非常方便的支持。本文将利用shutil实现拷贝文件功能,需要的可以参考一下
    2022-07-07
  • Pygame的程序开始示例代码

    Pygame的程序开始示例代码

    这篇文章主要介绍了Pygame的程序开始的示例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • python看某个模块的版本方法

    python看某个模块的版本方法

    今天小编就为大家分享一篇python看某个模块的版本方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-10-10
  • Blender Python编程创建发光材质示例详解

    Blender Python编程创建发光材质示例详解

    这篇文章主要为大家介绍了Blender Python编程创建发光材质示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • matplotlib 曲线图 和 折线图 plt.plot()实例

    matplotlib 曲线图 和 折线图 plt.plot()实例

    这篇文章主要介绍了matplotlib 曲线图 和 折线图 plt.plot()实例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-04-04
  • django学习之ajax post传参的2种格式实例

    django学习之ajax post传参的2种格式实例

    AJAX除了异步的特点外,还有一个就是:浏览器页面局部刷新,下面这篇文章主要给大家介绍了关于django学习之ajax post传参的2种格式的相关资料,需要的朋友可以参考下
    2021-05-05
  • Python之Scrapy爬虫框架安装及使用详解

    Python之Scrapy爬虫框架安装及使用详解

    这篇文章主要为大家详细介绍了Python Scrapy爬虫框架安装及简单使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11

最新评论