Служба Pywin32 не запускается, не может прочитать файл JSON - PullRequest
1 голос
/ 02 ноября 2019

Я использовал инструменты Pywin32 и NSSM для создания службы Windows для своего приложения Flask. Я заметил, что служба не начинает выдавать мне сообщение:

The service did not return an error. This could be an internal Windows error or an internal service error

Я заметил, что, когда я удалил все ссылки на файл config.json (используемый для подключения к БД), созданная служба запускается. Мой service.py:

import win32serviceutil
import win32service
import win32event
import servicemanager
from multiprocessing import Process

from app import app


class Service(win32serviceutil.ServiceFramework):
    _svc_name_ = "TestService"
    _svc_display_name_ = "Test Service"
    _svc_description_ = "Tests Python service framework by receiving and echoing messages over a named pipe"

    def __init__(self, *args):
        super().__init__(*args)

    def SvcStop(self):
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        self.process.terminate()
        self.ReportServiceStatus(win32service.SERVICE_STOPPED)

    def SvcDoRun(self):
        self.process = Process(target=self.main)
        self.process.start()
        self.process.run()

    def main(self):
        app.run()


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

Следующий пример реализации app.py работает:

from flask import Flask
import json
import socket

app = Flask(__name__)


host = "<IP>"
user = "<username>"
passwd = "XXXXX"
DB = "YYYYY"

@app.route('/')
def hello_world():
    return 'Hello, World!'

app.run(host = "0.0.0.0",debug = False, port=9000, threaded=True)

Но как только я добавляю код для чтения учетных данных БД из конфига. Файл json, созданный сервис выдает ошибку:

conf = open('.\\config.json', "r")
data = json.loads(conf.read())
db_conf = data['db_connection']

host = db_conf['host']
user = db_conf['username']
passwd = db_conf['password']
DB = db_conf['DB']

Есть ли какие-либо проблемы с чтением файлов json с помощью pywin32? Когда я запускаю тот же файл app.py из командной строки, он читает все файлы json и работает без проблем.

...