无法启动用Python编写的Windows服务(win32serviceutil)

时间:2012-01-20 15:00:41

标签: python windows windows-services pywin32

我正在尝试启动一个简单的服务示例:

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:服务没有及时响应启动或控制请求”,但没有任何延迟。

我搜索了一个解决方案,该解决方案表示当pythonservice.exe无法找到python27.dll时会发生这种情况。它确实无法将C:\Python27添加到PATH。现在pythonservice.exe运行正常,但错误1053仍在那里。

我在Windows 7旗舰版上使用pywin32 216运行Python 2.7.2并具有管理员权限。

8 个答案:

答案 0 :(得分:11)

另外,感谢您指出它可能是DLL问题,这使我找到了正确的解决方案。

你需要做的是将Python27添加到SYSTEM PATH,而不是添加到USER PATH,因为默认情况下python服务将作为“LocalSystem”安装,因此当它尝试启动时使用SYSTEM PATH变量 - 这就是为什么你可以从命令提示符运行它,你的用户路径是正确的。

希望它有所帮助!

答案 1 :(得分:3)

我相信如果您更改方法SvcDoRun

,您的问题将得到解决

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

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

答案 2 :(得分:2)

我也有这个问题,并且能够通过在我的"__main__"执行块中添加以下内容来解决它:

if len(sys.argv) == 1:
    servicemanager.Initialize()
    servicemanager.PrepareToHostSingle(RouterService)
    servicemanager.StartServiceCtrlDispatcher()
else:
    win32serviceutil.HandleCommandLine(RouterService)

(不要忘记在文件顶部导入servicemanager。)

我认为问题是Windows服务管理器运行没有参数的可执行文件(默认情况下),在这种情况下,需要正确地告诉应用程序启动服务,不调用SvcDoRun自动似乎。

正如其他人提到的,如果从命令行运行它,则需要路径映射。在我的应用程序中,我使用cx_freeze冻结了服务并使用可执行文件来安装服务,因此包含了所有依赖项。

答案 3 :(得分:2)

确保以不同于默认本地系统用户的用户身份运行该应用程序。将其替换为您能够成功运行debug命令的用户。

要替换用户,请转到Windows服务(开始> services.msc) 右键单击您创建的服务>属性>登录 取消选中本地系统帐户,然后输入您自己的帐户。 来自all python windows service can not start{error 1053}的人为我工作。

因为我只是为用户设置了PATH,所以以本地系统帐户运行时缺少环境。

答案 4 :(得分:1)

另一个有用的提示是添加以下行

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

之前打电话

win32serviceutil.HandleCommandLine(...)

通过这种方式,您可以从出现问题的服务中获得更多有用的信息。

答案 5 :(得分:0)

通过使用Python 3.5和PyInstaller遵循这些procedure,我可以运行服务

答案 6 :(得分:0)

错误原因可能来自不同的原因。除了使用日志流之外,我强烈建议考虑使用nssmhttp://nssm.cc/download

根据我的经验;为了用python文件,批处理文件(.bat)和可执行文件制作Windows服务,我付出了很多努力。与sc或使用win32serviceutil从原始python代码不同,Nssm是用于安装服务的出色工具。

具有一个调用主函数的模块,并在批处理文件中运行该模块。然后该批处理文件可以用于Windows服务。

在python模块中:

""" 
main.py 
""" 
from myCode import run.py

run()

在service.bat中:

python main.py

然后使用nssm可以轻松安装指向文件service.bat的Windows服务

答案 7 :(得分:0)

我也无法启动python服务,我安装了python39。

我的问题是缺少pywintypes39.dll 并导致错误1053无法启动服务

在路径中找到负责在Windows中启动python服务的模块 C:\Users\.....\AppData\Local\Programs\Python\Python39\Lib\site-packages\win32 pythonservice.exe

但缺少的.dll安装在名为lib的子文件夹中 \AppData\Local\Programs\Python\Python39\Lib\site-packages\win32\lib

将丢失的.dll从\Lib文件夹传输到根文件夹\win32,在其中pythonservice.exe将使服务程序可以访问它。

这对我有用。