Joh*_*hnJ 3 python python-watchdog
我正在尝试学习 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
Run Code Online (Sandbox Code Playgroud)
观察者设置如下:
#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()
Run Code Online (Sandbox Code Playgroud)
最后,像这样的动作:
#actions.py
import os
import subprocess
def run_something():
output = subprocess.check_output(['./run.sh'])
print output
return None
Run Code Online (Sandbox Code Playgroud)
..where./run.sh只是一个 shell 脚本,当在其.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)"
Run Code Online (Sandbox Code Playgroud)
但是,当我发出 apython observer.py然后执行touch job.doneon 时/path/to/some/directory/bin,我看到我的 shell 脚本./run.sh运行了 3 次而不是一次。
我很困惑为什么这会运行三次而不是一次(我确实删除了job.done我的 bash 脚本中的文件)
要调试看门狗脚本,打印看门狗看到的事件是很有用的。一个文件编辑或 CLI 命令(例如touch)可能会导致多个看门狗事件。例如,如果插入打印语句:
class ChangeHandler(FileSystemEventHandler):
def on_any_event(self, event):
print(event)
Run Code Online (Sandbox Code Playgroud)
记录每个事件,运行
% touch job.done
Run Code Online (Sandbox Code Playgroud)
产生
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'>
Run Code Online (Sandbox Code Playgroud)
上面有两个事件src_path的结束job.done。因此,
if getext(event.src_path) == '.done':
run_something()
Run Code Online (Sandbox Code Playgroud)
运行两次,因为有 aFileCreatedEvent和 a FileModifiedEvent。您最好只监控FileModifiedEvents。
| 归档时间: |
|
| 查看次数: |
5448 次 |
| 最近记录: |