Python腳本在Windows下以Service服務(wù)的形式定時(shí)運(yùn)行

Python腳本在Windows下以Service服務(wù)的形式定時(shí)運(yùn)行

1.簡(jiǎn)介

最近工作上有個(gè)需求,是需要在服務(wù)器中定時(shí)運(yùn)行腳本。以前定時(shí)任務(wù)都是在linux上通過crontab或者shell腳本跑的,而這次是需要在windows的服務(wù)器上運(yùn)行的。要完成這個(gè)需求,需要借助pywin32模塊把腳本寫成windows的服務(wù)形式。

2.簡(jiǎn)單的服務(wù)程序用例

這是一個(gè)相當(dāng)于模版一樣的代碼,在相應(yīng)的地方放進(jìn)自己要執(zhí)行的代碼即可。
test.py:

# -*- coding: utf-8 -*-

import os
import win32serviceutil
import win32service
import win32event
import datetime
from time import sleep


class TestService(win32serviceutil.ServiceFramework):
    _svc_name_ = "Test Ser"
    _svc_display_name_ = "Test Ser"
    _svc_description_ = "This is a Test Ser"

    def __init__(self, args):
        win32serviceutil.ServiceFramework.__init__(self, args)
        self.hWaitStop = win32event.CreateEvent(None, 0, 0, None)

    def SvcDoRun(self):
        # 定時(shí)任務(wù)
        while True:
            # 寫日志操作
            os.chdir('C:\\')
            with open('test_log.txt', 'a+') as f:
                f.write('test in | ' + datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S') + '\n')
                f.write('---------------------------------------------------------------------------' + '\n')
                f.write('\n')
            sleep(60)

    def SvcStop(self):
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        win32event.SetEvent(self.hWaitStop)


if __name__ == '__main__':
    win32serviceutil.HandleCommandLine(TestService)

這里是延時(shí)只是用了簡(jiǎn)單的sleep有需要的可以用APScheduler等第三方庫進(jìn)行定時(shí)。

3.注意事項(xiàng):

1.dll文件缺失

點(diǎn)開自己的python根目錄的\Lib\site-packages\win32 點(diǎn)擊pythonservice.exe會(huì)提示缺失pywintypes36.dll(我的是3.6版本)。
解決方法:需要到\Lib\site-packages\pywin32_system32把dll文件復(fù)制粘貼到Lib\site-packages\win32文件夾。再次運(yùn)行pythonservice.exe會(huì)發(fā)現(xiàn)沒有報(bào)錯(cuò)。

2.設(shè)置用戶環(huán)境變量

因?yàn)槲沂窃诒镜剡\(yùn)行服務(wù),所以要把python的環(huán)境變量添加到用戶環(huán)境變量,這樣服務(wù)才能正常啟動(dòng)。添加方法跟安裝python的時(shí)候相同。

服務(wù)的命令

# 安裝服務(wù)
python test.py install
# 服務(wù)自動(dòng)啟動(dòng)
python test.py --startup auto install 
# 更新服務(wù)
python test.py update
# 服務(wù)開始
python test.py start
# 重啟服務(wù)
python test.py restart 
# 停止服務(wù)
python test.py stop
# 卸載服務(wù)
python test remove

在調(diào)試時(shí)執(zhí)行了stop命令后,發(fā)現(xiàn)任務(wù)管理器里服務(wù)的進(jìn)程會(huì)處于正在停止?fàn)顟B(tài),這是是重新start不了的,可以通過命令行直接 tskill PID 強(qiáng)制停止。

結(jié)果

image.png
image.png
image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容