web-dev-qa-db-ja.com

Python(win32serviceutil)で記述されたWindowsサービスを開始できません

簡単なサービスの例を開始しようとしています。

someservice.py:

import win32serviceutil 
import win32service 
import win32event

class SmallestPythonService(win32serviceutil.ServiceFramework):
    _svc_name_ = "SmallestPythonService"
    _svc_display_name_ = "display service"

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

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

    def SvcDoRun(self):
        win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)

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

走ると

python someservice.py install

すべてが正常で、サービスはWindowsサービスリストに表示されますが、

python someservice.py start

「エラー1053:サービスは開始要求または制御要求にタイムリーに応答しませんでした」で失敗しますが、遅延はありません。

pythonservice.exepython27.dllを見つけられないときに起こるという解決策をグーグルで検索しました。実際にはできなかったので、C:\Python27PATHに追加しました。これでpythonservice.exeは正常に実行されますが、エラー1053はまだ存在します。

管理者権限のあるWindows7Ultimateでpywin32216を使用してPython 2.7.2を実行しています。

18
tas

また、DLLの問題である可能性があることを指摘していただき、ありがとうございます。それにより、適切な解決策を見つけることができました。

あなたがする必要があるのは、Python27をユーザーパスではなくシステムパスに追加することです。デフォルトではpythonサービスは 'LocalSystem'としてインストールされるので、システムパス変数を使用して開始します-そのため、コマンドプロンプトから実行できます。ユーザーパスは正しいです。

それが役に立てば幸い!

12
mpaf

メソッドを変更することで問題が解決すると思いますSvcDoRun

から

   def  SvcDoRun(self):
        win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)

   def  SvcDoRun(self):
        self.ReportServiceStatus(win32service.SERVICE_RUNNING)
        win32event.WaitForSingleObject(self.hWaitStop, win32event.INFINITE)
3

私もこの問題を抱えていて、"__main__"実行ブロックに以下を追加することで解決できました。

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

(ファイルの先頭にあるservicemanagerをインポートすることを忘れないでください)。

問題は、Windowsサービスマネージャーが実行可能ファイルを引数なしで実行することであると思います(デフォルト)。この場合、アプリケーションはサービスを開始するように適切に指示される必要があり、SvcDoRunは自動的に呼び出されません。どうやら。

他の人が述べたように、これをコマンドラインから実行する場合はパスマッピングが必要です。私のアプリケーションでは、cx_freezeでサービスをフリーズし、実行可能ファイルを使用してサービスをインストールし、すべての依存関係が含まれるようにしました。

3
Alex

もう1つの役立つヒントは、次の行を追加することです

_sys.frozen = 'windows_exe' # Fake py2exe so we can debug_

電話する前に

win32serviceutil.HandleCommandLine(...)

そうすれば、何がうまくいかないのかについて、サービスからより役立つ情報を得ることができます。

1
Jonathan

これらに従うことでサービスを実行できます 手順 Python 3.5とPyInstallerを使用して

0
Yajana

デフォルトのローカルシステムユーザーとは異なるユーザーでアプリケーションを実行していることを確認してください。デバッグコマンドを正常に実行できるユーザーに置き換えます。

ユーザーを置き換えるには、Windowsサービスに移動します([スタート]> [services.msc])。作成したサービスを右クリックします> [プロパティ]> [ログオン] [ローカルシステムアカウント]のチェックを外し、独自のアカウントを入力します。 from all python Windowsサービスを開始できません{エラー1053} 私のために働いた。

ユーザーにPATHを設定しただけなので、ローカルシステムアカウントで実行すると環境が不足します。

0
haulpd

エラーの原因はさまざまな理由で発生する可能性があります。ログフローを使用する以外に、nssmを考慮することを強くお勧めします: http://nssm.cc/download

私の経験から; pythonファイル、バッチファイル(.bat)、実行可能ファイルからWindowsサービスを作成するのに苦労しました。scやからとは異なり、Nssmはサービスをインストールするための優れたツールです。 raw python win32serviceutilを使用したコード。

Main関数を呼び出すモジュールを用意し、バッチファイル内でモジュールを実行します。その後、バッチファイルをWindowsサービスに使用できます。

pythonモジュール:

""" 
main.py 
""" 
from myCode import run.py

run()

Service.bat内:

python main.py

そして、nssmを使用すると、service.batファイルを指すWindowsサービスを簡単にインストールできます。