我正在使用此处找到的模板:Is it possible to run a Python script as a service in Windows? If possible, how?
这是我的run.py,我已按照上述链接中的说明安装了服务。
from app import app
import win32serviceutil
import win32service
import win32event
import servicemanager
import socket
class AppServerSvc (win32serviceutil.ServiceFramework):
_svc_name_ = "Flask App"
_svc_display_name_ = "Flask App"
def __init__(self,args):
win32serviceutil.ServiceFramework.__init__(self,args)
self.hWaitStop = win32event.CreateEvent(None,0,0,None)
socket.setdefaulttimeout(60)
def SvcStop(self):
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
win32event.SetEvent(self.hWaitStop)
def SvcDoRun(self):
servicemanager.LogMsg(servicemanager.EVENTLOG_INFORMATION_TYPE,
servicemanager.PYS_SERVICE_STARTED,
(self._svc_name_,''))
self.main()
def main(self):
app.run(host = '192.168.1.6')
if __name__ == '__main__':
win32serviceutil.HandleCommandLine(AppServerSvc)
然而,当我尝试启动服务时,我收到消息:
"本地计算机上的Flask App服务已启动,然后停止。 如果某些服务未被其他服务或程序使用,则会自动停止。"
知道我做错了什么吗?我尝试了各种用户帐户 - 我不认为这是一个权限问题。
谢谢!
答案 0 :(得分:10)
我无法访问WSGIRequestHandler
之外的Flask中的request
,因此我使用了Process
。
import win32serviceutil
import win32service
import win32event
import servicemanager
from multiprocessing import Process
from app import app
class Service(win32serviceutil.ServiceFramework):
_svc_name_ = "TestService"
_svc_display_name_ = "Test Service"
_svc_description_ = "Tests Python service framework by receiving and echoing messages over a named pipe"
def __init__(self, *args):
super().__init__(*args)
def SvcStop(self):
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
self.process.terminate()
self.ReportServiceStatus(win32service.SERVICE_STOPPED)
def SvcDoRun(self):
self.process = Process(target=self.main)
self.process.start()
self.process.run()
def main(self):
app.run()
if __name__ == '__main__':
win32serviceutil.HandleCommandLine(Service)
答案 1 :(得分:2)
想出来 - 我在app.run()中打开了调试选项。一旦我删除了它,那就好了!
当服务启动并正常运行(我可以从网络上的另一台计算机访问我的烧瓶应用程序)时,它无法停止。在使用我发布的模板的帖子中,作者提到了设置标志以正确停止服务的事情。
任何人都知道他的意思是什么以及如何编码以正确停止服务?
答案 2 :(得分:-3)
我在SvcStop()的最后一行添加了我的代码。 " self.ReportServiceStatus(win32service.SERVICE_STOPPED)"
就我而言,它适用于停止服务。
from app import app
import win32serviceutil
import win32service
import win32event
import servicemanager
import socket
class AppServerSvc (win32serviceutil.ServiceFramework):
_svc_name_ = "Flask App"
_svc_display_name_ = "Flask App"
def __init__(self,args):
win32serviceutil.ServiceFramework.__init__(self,args)
self.hWaitStop = win32event.CreateEvent(None,0,0,None)
socket.setdefaulttimeout(60)
def SvcStop(self):
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
win32event.SetEvent(self.hWaitStop)
# !important! to report "SERVICE_STOPPED"
self.ReportServiceStatus(win32service.SERVICE_STOPPED)
def SvcDoRun(self):
servicemanager.LogMsg(servicemanager.EVENTLOG_INFORMATION_TYPE,
servicemanager.PYS_SERVICE_STARTED,
(self._svc_name_,''))
self.main()
def main(self):
app.run(host = '192.168.1.6')
if __name__ == '__main__':
win32serviceutil.HandleCommandLine(AppServerSvc)