为什么在日志框架中调用日志框架不会产生输出到日志(file,stdout,...)?Python日志记录模块在安装的windows服务中不起作用
我的Python服务具有一般形式:
import logging
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
fh = logging.FileHandler('out.log')
logger.addHandler(fh)
logger.error("OUTSIDE")
class Service (win32serviceutil.ServiceFramework):
_svc_name_ = "example"
_svc_display_name_ = "example"
_svc_description_ = "example"
def __init__(self,args):
logger.error("NOT LOGGED")
win32serviceutil.ServiceFramework.__init__(self,args)
self.hWaitStop = win32event.CreateEvent(None,0,0,None)
servicemanager.LogMsg(servicemanager.EVENTLOG_INFORMATION_TYPE,
servicemanager.PYS_SERVICE_STARTED,
(self._svc_name_,''))
def SvcStop(self):
self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
win32event.SetEvent(self.hWaitStop)
self.stop = True
def SvcDoRun(self):
self.ReportServiceStatus(win32service.SERVICE_RUNNING)
self.main()
def main(self):
# Service Logic
logger.error("NOT LOGGED EITHER")
pass
到logger.error第一次调用产生的输出,而不是两个服务类中(即使安装服务,使后确保它正在运行) 。
您是否正在查看日志文件的正确文件夹?服务在Windows文件夹中运行。 – CoreTech 2013-02-11 14:18:38
设置输出日志的绝对路径会有所作为吗? – 2013-02-11 14:29:20
实际上我将它设置为绝对路径(在我的示例中未显示)。我看到正在创建的日志文件,并且第一个logger.error(“OUTSIDE”)消息在那里。另外两个没有被记录。 – mpaf 2013-02-11 14:47:53