3

私は python-watchdog を学ぼうとしていますが、設定したジョブが複数回実行される理由がちょっとわかりません。だから、ここに私のセットアップがあります:

#handler.py
import os
from watchdog.events import FileSystemEventHandler
from actions import run_something

def getext(filename):
    return os.path.splitext(filename)[-1].lower()

class ChangeHandler(FileSystemEventHandler):

    def on_any_event(self, event):

        if event.is_directory:
            return
        if getext(event.src_path) == '.done':
            run_something()
        else: 
            print "event not directory.. exiting..."
            pass

オブザーバーは次のように設定されています。

#observer.py
import os
import time
from watchdog.observers import Observer
from handler import ChangeHandler

BASEDIR = "/path/to/some/directory/bin"

def main():

    while 1:

        event_handler = ChangeHandler()
        observer = Observer()
        observer.schedule(event_handler, BASEDIR, recursive=True)
        observer.start()
        try:
            while True:
                time.sleep(1)
        except KeyboardInterrupt:
            observer.stop()
        observer.join()

 if __name__ == '__main__':
    main()

そして最後に、次のようなアクション:

#actions.py
import os
import subprocess

def run_something():
    output = subprocess.check_output(['./run.sh'])
    print output
    return None

..whereは、拡張子を持つファイルが見つかった./run.shときに実行したい単なるシェル スクリプトです。.done/path/to/some/directory/bin

#run.sh
#!/bin/bash
echo "Job Start: $(date)"
rm -rf /path/to/some/directory/bin/job.done # remove the .done file
echo "Job Done: $(date)"

ただし、 a を発行してからonpython observer.pyを実行すると、シェル スクリプトが 1 回ではなく 3 回実行されることがわかります。touch job.done/path/to/some/directory/bin./run.sh

これが1回だけでなく3回実行される理由がわかりません(job.donebashスクリプトでファイルを削除します)

4

1 に答える 1

6

ウォッチドッグ スクリプトをデバッグするには、ウォッチドッグがイベントとして認識しているものを出力すると便利です。などの 1 つのファイル編集または CLI コマンドで、touch複数のウォッチドッグ イベントが発生する可能性があります。たとえば、print ステートメントを挿入すると、次のようになります。

class ChangeHandler(FileSystemEventHandler):

    def on_any_event(self, event):
        print(event)

実行中のすべてのイベントをログに記録する

% touch job.done

生成する

2014-12-24 13:11:02 - <FileCreatedEvent: src_path='/home/unutbu/tmp/job.done'>
2014-12-24 13:11:02 - <DirModifiedEvent: src_path='/home/unutbu/tmp'>
2014-12-24 13:11:02 - <FileModifiedEvent: src_path='/home/unutbu/tmp/job.done'>

上には でsrc_path終わる 2 つのイベントがありましたjob.done。したがって、

    if getext(event.src_path) == '.done':
        run_something()

FileCreatedEventとがあるため、 は 2 回実行されFileModifiedEventます。のみを監視する方がよい場合がありますFileModifiedEvent

于 2014-12-24T18:13:20.640 に答える