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

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

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

Ответ 1

Кроме того, спасибо за указание, что это может быть проблема с DLL, которая заставила меня найти правильное решение.

Что вам нужно сделать, так это добавить Python27 в SYSTEM PATH, а не в USER PATH, так как по умолчанию служба python будет установлена ​​как "LocalSystem", и поэтому, когда она пытается запустить, она использует SYSTEM PATH переменная - поэтому вы можете запустить ее из командной строки, ваш USER PATH прав.

Надеюсь, что это поможет!

Ответ 2

Я считаю, что ваша проблема будет исправлена, если вы измените метод SvcDoRun

от

   def  SvcDoRun(self):
        win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)

to

   def  SvcDoRun(self):
        self.ReportServiceStatus(win32service.SERVICE_RUNNING)
        win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)

Ответ 3

Еще один полезный совет - добавить следующую строку

sys.frozen = 'windows_exe' # Fake py2exe so we can debug

перед вызовом

win32serviceutil.HandleCommandLine(...)

Таким образом, вы можете получить более полезную информацию от службы о том, что пойдет не так.