Python HTTP服务器无法在Windows服务中发送响应

问题描述:

我已经编写了一个简单的HTTP服务器,并使用pywin32将其转换为Windows服务。服务器在调试器中运行时成功处理请求,在获取请求的实际服务中,但挂起在send_response操作上。可能是什么原因?Python HTTP服务器无法在Windows服务中发送响应

from http.server import BaseHTTPRequestHandler, HTTPServer 
import win32serviceutil 
import win32service 
import sys 

PORT_NUMBER = 6363 

class myHandler(BaseHTTPRequestHandler): 
    def do_GET(self): 
     self.send_response(200) 
     self.send_header('Content-type', 'text/html') 
     self.end_headers() 
     self.wfile.write(bytes("Hello World !", "utf-8")) 
     return 

class TestSvc(win32serviceutil.ServiceFramework): 
    _svc_name_ = "TestSvc" 
    _svc_display_name_ = "Test Service" 
    _svc_description_ = "Tests server inside service." 

    def __init__(self, args): 
     win32serviceutil.ServiceFramework.__init__(self, args) 
     self.server = HTTPServer(('', PORT_NUMBER), myHandler) 

    def SvcDoRun(self): 
     self.ReportServiceStatus(win32service.SERVICE_RUNNING) 
     print('Started httpserver on port ', PORT_NUMBER) 
     self.server.serve_forever() 

    def SvcStop(self): 
     self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING) 
     self.server.shutdown() 

#sys.frozen = 'windows_exe' 
if __name__ == '__main__': 
    win32serviceutil.HandleCommandLine(TestSvc, argv=sys.argv) 
+0

以管理员身份运行?可能是特权问题 –

+0

pythonservice.exe设置为以管理员身份运行 – Natalia

实际上,它在执行sys.stderr.write(这是BaseHTTPRequestHandler的默认日志记录输出)时挂起。所以我在我的请求处理器类中重写了log_message函数,现在它工作正常。