service_adapter.py

Posted munan-zhou

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了service_adapter.py相关的知识,希望对你有一定的参考价值。

# -*- coding:utf-8 -*-

import os
import sys
import time
import servicemanager
import win32serviceutil
import win32service
import win32event
import winerror


class ServiceAdapter(win32serviceutil.ServiceFramework):
    _svc_name_ = "ServiceAdapter"
    _svc_display_name_ = Service_Adapter
    _svc_description_ = Windows service adapter

    def __init__(self, args):
        win32serviceutil.ServiceFramework.__init__(self, args)
        self.stop_event = win32event.CreateEvent(None, 0, 0, None)

    def SvcDoRun(self):
        self.ReportServiceStatus(win32service.SERVICE_START_PENDING)
        self.start()
        self.ReportServiceStatus(win32service.SERVICE_RUNNING)
        self.running()
        # Write a stop message.
        servicemanager.LogMsg(
            servicemanager.EVENTLOG_INFORMATION_TYPE,
            servicemanager.PYS_SERVICE_STOPPED,
            (self._svc_name_, ‘‘)
        )

    def SvcStop(self):
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        self.stop()
        self.log("SetEvent stop_event")
        win32event.SetEvent(self.stop_event)
        self.log("ReportServiceStatus SERVICE_STOPPED")
        self.ReportServiceStatus(win32service.SERVICE_STOPPED)
        self.log("ReportServiceStatus SERVICE_STOPPED end.")


    @classmethod
    def service_main(cls):
        if len(sys.argv) == 1:
            try:
                event_src_dll = os.path.abspath(servicemanager.__file__)
                servicemanager.PrepareToHostSingle(cls)
                servicemanager.Initialize(cls.__name__, event_src_dll)
                servicemanager.StartServiceCtrlDispatcher()
            except Exception as exp:
                if exp.args[0] == winerror.ERROR_FAILED_SERVICE_CONTROLLER_CONNECT:
                    win32serviceutil.usage()
        else:
            try:
                win32serviceutil.HandleCommandLine(cls)
            except Exception as ex:
                cls.log(ex)
                exit(1)

    def start(self):
        self.log("start")
        pass

    def stop(self):
        self.log("stop")
        pass

    def running(self):
        while True:
            self.log("running")
            # self._log()
            time.sleep(5)

    @classmethod
    def log(cls, msg):
        with open("{}.log".format(cls._svc_name_), "a") as fp:
            fp.write("{} {}".format(time.strftime("%Y-%m-%d %H:%M:%S", time.localtime()), msg))
            fp.write("
")


if __name__ == __main__:
    # program_path = os.path.abspath(os.path.dirname(__file__))
    # ServiceAdapter.log(program_path)

    try:
        ServiceAdapter.service_main()
    except (SystemExit, KeyboardInterrupt):
        raise
    except:
        print("Something went bad!")
        import traceback
        traceback.print_exc()

    pass

 

以上是关于service_adapter.py的主要内容,如果未能解决你的问题,请参考以下文章

VSCode自定义代码片段——CSS选择器

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

片段和活动之间的核心区别是啥?哪些代码可以写成片段?

VSCode自定义代码片段——.vue文件的模板

VSCode自定义代码片段6——CSS选择器

VSCode自定义代码片段——声明函数