-
-
Save tnibert/f62d3e578a480791fa5c8c6141c6cbf2 to your computer and use it in GitHub Desktop.
An example Windows service implemented with pywin32 wrappers. #python #windows-service #pywin32
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
import win32serviceutil | |
import win32service | |
import win32event | |
import servicemanager | |
import socket | |
import time | |
import logging | |
logging.basicConfig( | |
filename = 'c:\\Temp\\hello-service.log', | |
level = logging.DEBUG, | |
format = '[helloworld-service] %(levelname)-7.7s %(message)s' | |
) | |
class HelloWorldSvc (win32serviceutil.ServiceFramework): | |
_svc_name_ = "HelloWorld-Service" | |
_svc_display_name_ = "HelloWorld Service" | |
def __init__(self,args): | |
win32serviceutil.ServiceFramework.__init__(self,args) | |
self.stop_event = win32event.CreateEvent(None,0,0,None) | |
socket.setdefaulttimeout(60) | |
self.stop_requested = False | |
def SvcStop(self): | |
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING) | |
win32event.SetEvent(self.stop_event) | |
logging.info('Stopping service ...') | |
self.stop_requested = True | |
def SvcDoRun(self): | |
servicemanager.LogMsg( | |
servicemanager.EVENTLOG_INFORMATION_TYPE, | |
servicemanager.PYS_SERVICE_STARTED, | |
(self._svc_name_,'') | |
) | |
self.main() | |
def main(self): | |
logging.info(' ** Hello PyWin32 World ** ') | |
# Simulate a main loop | |
for i in range(0,50): | |
if self.stop_requested: | |
logging.info('A stop signal was received: Breaking main loop ...') | |
break | |
time.sleep(5) | |
logging.info("Hello at %s" % time.ctime()) | |
return | |
if __name__ == '__main__': | |
win32serviceutil.HandleCommandLine(HelloWorldSvc) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment