검색하기귀찮아서만든블로그

[windows service] python 서비스 테스트 본문

개발/언어

[windows service] python 서비스 테스트

hellworld 2020. 8. 27. 15:45

가상화 서비스에서 인스턴스 설치 후에 제품 자동 설치를 위해
windows service에서 batch 파일을 통해서 mfc 응용(UI 있음) 실행이 가능한지 확인이 필요했다.

응용 프로그램에서 ui 를 로드하는 부분은 모두 예외 처리 작업 선 진행.


# 파일명 TestService.py 

import servicemanager
import socket
import sys
import win32event
import win32service
import win32serviceutil
import subprocess, os

class TestService(win32serviceutil.ServiceFramework):
    _svc_name_ = "TestService"
    _svc_display_name_ = "Test Service"

    def __init__(self, args):
        win32serviceutil.ServiceFramework.__init__(self, args)
        self.hWaitStop = win32event.CreateEvent(None, 0, 0, None)
        socket.setdefaulttimeout(60)
        self.bMgrRun = False
    def SvcStop(self):
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        win32event.SetEvent(self.hWaitStop)

    def SvcDoRun(self):
        rc = None
        while rc != win32event.WAIT_OBJECT_0:
            with open(r'C:\project\TestService.log', 'a') as f:
                f.write('test service running...\n')

                if not self.bMgrRun:
                    # 매니저 직접 실행
                    #r = subprocess.call([r'C:\project\mgr.exe', '/silent'], shell=True) # ok!
                    #f.write('run ret : {} \n'.format(r))

                    # 배치 파일 실행
                    r = subprocess.Popen([os.path.abspath(r'C:\project\runManager.bat')], shell=True)
                    stdout, stderr = r.communicate();
                    f.write('run bat ret : {} stdout:{} / stderr:{}\n'.format(r, stdout, stderr))
                    r.wait()

                    self.bMgrRun = True

            rc = win32event.WaitForSingleObject(self.hWaitStop, 5000)

if __name__ == '__main__':
    if len(sys.argv) == 1:
        servicemanager.Initialize()
        servicemanager.PrepareToHostSingle(TestService)
        servicemanager.StartServiceCtrlDispatcher()
    else:
        win32serviceutil.HandleCommandLine(TestService)


- 코드 참조 : https://ko.coder.work/so/python/474010
- exe 파일 생성 : pyinstaller --onefile --hidden-import win32timezone TestService.py
. --hidden-import win32timezone : 실행파라미터 처리하는 곳에서 패키지 누락되서 에러 나는 증상 해결
. --onefile : 각종 패키지들은 exe 에 모두 포함 시킴

- 서비스 사용법 (서비스 구동 시 최초 1회 배치 파일을 실행함)
. 서비스 등록 : TestService.exe install
. 서비스 수정 : TestService.exe update
. 서비스 삭제 : TestService.exe remove
. 서비스 시작 : TestService.exe start
. 서비스 중지 : TestService.exe stop


exe 실행 배치 파일

@echo off start /d "C:\project\" /b mgr.exe /silent 

- 서비스에서 실행되야 하기 때문에 echo off 가 꼭 있어야 정상 동작 했음.