python方法报错使程序停止,使用Python写Windows Service服务程序

1.背景

如果你想用Python开发Windows程序,并让其开机启动等,就必须写成windows的服务程序Windows Service,用Python来做这个事情必须要借助第三方模块pywin32,自己去下载然后安装。

2.实例

#encoding=utf-8

importwin32serviceutilimportwin32serviceimportwin32eventimportosimportloggingimportinspectclassPythonService(win32serviceutil.ServiceFramework):

_svc_name_= "PythonService"_svc_display_name_= "jlw Python Service Test"_svc_description_= "这是一段python服务代码"

def __init__(self, args):

win32serviceutil.ServiceFramework.__init__(self, args)

self.hWaitStop=win32event.CreateEvent(None, 0, 0, None)

self.logger=self._getLogger()

self.run=Truedef_getLogger(self):

logger= logging.getLogger(‘[PythonService]‘)

this_file=inspect.getfile(inspect.currentframe())

dirpath=os.path.abspath(os.path.dirname(this_file))

handler= logging.FileHandler(os.path.join(dirpath, "service.log"))

formatter= logging.Formatter(‘%(asctime)s %(name)-12s %(levelname)-8s %(message)s‘)

handler.setFormatter(formatter)

logger.addHandler(handler)

logger.setLevel(logging.INFO)returnloggerdefSvcDoRun(self):importtime

self.logger.info("service is run....")whileself.run:

self.logger.info("I am runing....")

time.sleep(2)defSvcStop(self):

self.logger.info("service is stop....")

self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)

win32event.SetEvent(self.hWaitStop)

self.run=Falseif __name__ == ‘__main__‘:

win32serviceutil.HandleCommandLine(PythonService)

解释一下代码:

1).在类PythonService的__init__函数执行完后,系统服务开始启动,windows系统会自动调用SvcDoRun函数,这个函数的执行不可以结束,因为结束就代表服务停止。所以当我们放自己的代码在SvcDoRun函数中执行的时候,必须确保该函数不退出。

2).当停止服务的时候,系统会调用SvcDoStop函数,该函数通过设置标志位等方式让SvcDoRun函数退出,就是正常的停止服务。例子中是通过event事件让SvcDoRun函数停止等待,从而退出该函数,从而使服务停止。系统关机时不会调用SvcDoStop函数,所以这种服务是可以设置为开机自启的。

3.服务操作命令

#1.安装服务python PythonService.py install#2.让服务自动启动python PythonService.py--startup auto install#3.启动服务python PythonService.py start#4.重启服务python PythonService.py restart#5.停止服务python PythonService.py stop#6.删除/卸载服务python PythonService.py remove

4.报错处理

(1)安装服务python PythonService.py install时报错

提示:安装 py Error installing service: 拒绝访问。 (5)

20201221121750729641.png

原因:权限不够需要以管理员权限运行

解决方案:CDM管理员权限运行

具体方法:

第一步:先进到C:\Windows\SysWOW64\cmd.exe上右键,以管理员身份运行;

第二步:在此dos下,进到python项目目录,用pipenv shell进到当前项目虚拟环境下

20201221121750855648.png

第三步:再次执行python PythonService.py install

(2)启动服务python PythonService.py start时报错

报错提示:  服务无法启动:服务没有及时响应启动或控制请求 。1053

解决方案:

把当前项目虚拟环境目录下的Lib\site-packages\win32和Lib\site-packages\pywin32_system32目录添加到环境变量的系统变量中。

如下两个目录在当前项目虚拟环境目录

C:\Users\Administrator\.virtualenvs\pywindwos-IdJ1nAi2\Lib\site-packages\pywin32_system32

C:\Users\Administrator\.virtualenvs\pywindwos-IdJ1nAi2\Lib\site-packages\win32;

5.使用pyinstaller打包exe

pyinstaller.exe -F -c PythonService.py

原文:https://www.cnblogs.com/hzjdpawn/p/14167087.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值