Не удается запустить службу Windows, написанную на Python (win32serviceutil)

Я пытаюсь запустить простой пример службы:

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: служба не ответила на запрос запуска или управления своевременно», но задержки нет.

Я поискал в Google решение, в котором говорилось, что это происходит, когда pythonservice.exe не может найти python27.dll . На самом деле это было невозможно, поэтому я добавил C: \ Python27 в PATH . Теперь pythonservice.exe работает нормально, но ошибка 1053 все еще существует.

Я запускаю Python 2.7.2 с pywin32 216 в Windows 7 Ultimate с правами администратора.

17
задан Chris 21 January 2012 в 14:55
поделиться