【发布时间】:2014-12-24 18:03:06
【问题描述】:
我正在尝试学习 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
..其中./run.sh 只是一个shell 脚本,当在/path/to/some/directory/bin 上找到扩展名为.done 的文件时,我想运行它
#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)"
但是,当我发出python observer.py 然后在/path/to/some/directory/bin 上执行touch job.done 时,我看到我的shell 脚本./run.sh 运行了3 次而不是1 次......
我很困惑为什么它运行三次而不是一次(我确实删除了我的 bash 脚本中的 job.done 文件)
【问题讨论】:
-
‘While 1’ 和 ‘While true’ 是糟糕的代码,我猜你的代码甚至没有必要,因为‘join’调用通常会阻塞,直到满足条件。您的代码将在某些时候无限期阻塞,创建一个浪费系统资源的僵尸进程
-
实际上,我直接从教程中提取了代码:ginstrom.com/scribbles/2012/05/10/… 我现在已经从代码中删除了两个
‘While 1‘ and ‘While true‘。再次感谢您的提示。