Can';t启动用Python编写的Windows服务(win32serviceutil)

Can';t启动用Python编写的Windows服务(win32serviceutil),python,windows,windows-services,pywin32,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"

我尝试开始一个简单的服务示例:

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 Ultimate上运行Python 2.7.2和pywin32 216,并具有管理员权限。

我相信通过更改SvcDoRun方法,您的问题会得到解决


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

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


希望有帮助

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

sys.freezed='windows_exe'#伪造py2exe以便我们可以调试

在你打电话之前

win32serviceutil.HandleCommandLine(…)


这样,您可以从错误服务中获得更多有用的信息

我也遇到了这个问题,通过将以下内容添加到我的
“\uuuuu main\uuuuu”
执行块中,我得以解决这个问题:

if len(sys.argv) == 1:
    servicemanager.Initialize()
    servicemanager.PrepareToHostSingle(RouterService)
    servicemanager.StartServiceCtrlDispatcher()
else:
    win32serviceutil.HandleCommandLine(RouterService)
(不要忘记在文件顶部导入servicemanager)

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


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

我可以通过使用Python 3.5和PyInstaller来运行服务。

错误的原因可能不同。除了使用日志流,我强烈建议考虑
nssm

根据我的经验;为了从python文件、批处理文件(.bat)和可执行文件中创建windows服务,我做了很多努力。Nssm是一个很好的工具,可以使用它来安装您的服务,这与
sc
或使用win32serviceutil的原始python代码不同

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

在python模块中:

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

run()
In service.bat:

python main.py

然后使用nssm,您可以轻松地安装指向文件服务的windows服务。bat

请确保使用与默认本地系统用户不同的用户运行应用程序。将其替换为您能够成功运行调试命令的用户

要替换用户,请转到windows服务(开始>服务.msc) 右键单击您创建的服务>属性>登录 取消选中本地系统帐户并输入您自己的帐户。 他为我工作


因为我只是为用户设置了路径,所以在本地系统帐户上运行时它缺少环境

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

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

在路径中可以找到负责在windows中启动python服务的模块
C:\Users\..…\AppData\Local\Programs\Python\39\Lib\site packages\win32 pythonservice.exe

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

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


这对我有用。

这对我有用,运行Python 2.6.6(64位)和pywin32 216 amd64-py26。但我意识到这并没有多大帮助。在Windows 7 Pro.+1上,如果
pythonservice.exe
无法找到
python27.dll
,则会发生错误1053。我花了很长时间才弄明白!谢谢:)在这种情况下,也可以将这些目录添加到系统路径中:
C:\Python27\Lib\site packages\win32
C:\Python27\Lib\site packages\pywin32\u system32
。这将使您更容易地使用pythonservice。@BuvinJ这修复了我在使用pythonservice.exe时的错误1053。谢谢大家!@mpaf您能否帮助描述如何向系统路径添加内容?啊,我明白了,您只需将其添加到“系统控制面板”中的整个计算机系统路径中。就我个人而言,我必须添加anaconda,因为在这个解决方案中,我在Python3.8上工作,我尝试了其他解决方案,例如将win32添加到系统路径,也将pywintypes38.dll添加到win32,但这些都不起作用。
""" 
main.py 
""" 
from myCode import run.py

run()
python main.py