Я пытаюсь запустить простой пример службы:
someservice.py:
import win32serviceutil
import win32service
import win32event
class SmallestPythonService(win32serviceutil.ServiceFramework):
_svc_name_ = "SmallestPythonService"
_svc_display_name_ = "display service"
def __init__(self, args):
win32serviceutil.ServiceFramework.__init__(self, args)
self.hWaitStop = win32event.CreateEvent(None, 0, 0, None)
def SvcStop(self):
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
win32event.SetEvent(self.hWaitStop)
def SvcDoRun(self):
win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)
if __name__=='__main__':
win32serviceutil.HandleCommandLine(SmallestPythonService)
Когда я запустил
python someservice.py install
все в порядке, и служба появляется в списке служб Windows, но
python someservice.py start
завершается с ошибкой "Ошибка 1053: служба не отвечала на запрос запуска или управления своевременно", но нет никакой задержки.
Я googled решение, которое говорит, что это происходит, когда pythonservice.exe
не может найти python27.dll
. На самом деле это невозможно, поэтому я добавил C:\Python27
в PATH
. Теперь pythonservice.exe
работает нормально, но Ошибка 1053 все еще существует.
Я запускаю Python 2.7.2 с pywin32 216 на Windows 7 Ultimate с привилегиями администратора.