python 创建 window service 无法启动

2016-01-22 01:53:55 +08:00
 skywatcher

服务可以安装,但是启动就自动停止,弹窗提示本地计算机上的 HelloWorld Service 启动后停止,某些服务在未由其他服务或程序使用时将自动停止,通过run.py运行没有问题,求解什么原因?

class HelloWorldSvc (win32serviceutil.ServiceFramework):
    _svc_name_ = "HelloWorld-Service"
    _svc_display_name_ = "HelloWorld Service"

    def __init__(self,args):
        win32serviceutil.ServiceFramework.__init__(self,args)
        self.stop_event = win32event.CreateEvent(None,0,0,None)
        socket.setdefaulttimeout(60)
        self.stop_requested = False

    def SvcStop(self):
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        win32event.SetEvent(self.stop_event)
        logging.info('Stopping service ...')
        self.stop_requested = True

    def SvcDoRun(self):
        servicemanager.LogMsg(
            servicemanager.EVENTLOG_INFORMATION_TYPE,
            servicemanager.PYS_SERVICE_STARTED,
            (self._svc_name_, '')
        )
        self.main()

    @staticmethod
    def main():
        file_path = os.path.split(os.path.realpath(__file__))[0] + '\\run.py'
        print file_path
        try:
            execfile(file_path)
        except:
            pass

if __name__ == '__main__':
     win32serviceutil.HandleCommandLine(HelloWorldSvc)
2774 次点击
所在节点    Python
6 条回复
webdev
2016-01-22 09:48:04 +08:00
看下你安装的服务是在哪个用户下运行的(猜测),改成你自己登陆的用户试试
chilaoqi
2016-01-22 09:59:37 +08:00
刚好最近刚做完。 http://chixq.com/articles/windows-agent/

运行 eventvwr.msc 可以查看 service 出错事件是什么。
大多数情况,是系统 local system ( service 默认)账户不能取到你写的 python module 。可以 cmd -> python -> import <your_module> 看是否成功。所以直接安装到 site-packages 肯定 OK 。

run.py 肯定是可以的,注册 service 相对路径。 debug 肯定也可以。
skywatcher
2016-01-22 15:12:10 +08:00
@webdev 修改运行服务的用户?我试试看
skywatcher
2016-01-22 15:32:04 +08:00
@chilaoqi 是这样的,我刚看了你的文章,第一点没试(我是绝对路径调用`file_path = os.path.split(os.path.realpath(__file__))[0] + '\\run.py'`)所以路径下有文件应该不存在 import 问题。
第二点,我取消了 print 语句。但是我代码里有对 exe 文件进行调用, exe 文件有内容输出,是不是也会导致无法启动?
skywatcher
2016-01-22 21:19:03 +08:00
@chilaoqi 服务属性显示使用的是本地账户;取消了 print 和执行 exe 的内容输出(执行 run.py 不会有任何输出),但是服务还是之前那个错误 /(ㄒoㄒ)/~~
chilaoqi
2016-01-22 23:01:02 +08:00
@skywatcher 运行-> eventvwr.msc 可以看到服务启动不了的具体报错是什么

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/252513

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX