Watchdog (osx) не уведомляет об удаленных сетевых изменениях

Я использую Watchdog для нерекурсивного мониторинга сетевого каталога на предмет создания определенного шаблона файлов с течением времени. Проблема заключается в том, что, хотя при локальном тестировании все работает замечательно, если я вношу изменения в контролируемый каталог с удаленной машины, события не запускаются.

Вот конкретные детали моей конфигурации:

  • OSX
  • мониторинг одного каталога, без рекурсии, на NFS монтировании
  • python 2.6

Пример моей проблемы можно легко воспроизвести, используя стоковый пример фрагмента:

import sys
import time
import logging
from watchdog.observers import Observer
from watchdog.events import LoggingEventHandler

if __name__ == "__main__":
    logging.basicConfig(level=logging.INFO,
                        format='%(asctime)s - %(message)s',
                        datefmt='%Y-%m-%d %H:%M:%S')
    event_handler = LoggingEventHandler()
    observer = Observer()
    observer.schedule(event_handler, path=sys.argv[1], recursive=False)
    observer.start()
    try:
        while True:
            time.sleep(1)
    except KeyboardInterrupt:
        observer.stop()
    observer.join()

Если вы запустите это на сетевом каталоге, а затем внесете изменения с той же системы, события будут отправлены. Но если затем внести изменения в каталог с другой машины в сети, никаких событий не отправляется.

Я что-то упустил в ограничениях kqueue (или это может быть FSEvents на OSX, так как там говорится, что Watchdog предпочитает его первым)?

Я был в восторге от этого пакета python и собирался начать использовать его в других скриптах для замены опроса файловой системы, но я не могу найти никакой информации о том, почему я вижу эту проблему.

Обновление

Я также протестировал MacFSEvents и получил ту же проблему. Затем я модифицировал приведенный выше тестовый скрипт, чтобы принудительно попробовать разных наблюдателей:

# does not work with remote changes
from watchdog.observers.fsevents import FSEventsObserver as Observer
# does not work with remote changes
from watchdog.observers.kqueue import KqueueObserver as Observer
# only option that works because its actually polling every second
from watchdog.observers.polling import PollingObserver as Observer

Так что, по крайней мере, сейчас я могу использовать наблюдателя опроса и не изменять свой код, пока кто-нибудь не прольет свет на реальную проблему, с которой я столкнулся.

7
задан jdi 29 February 2012 в 01:45
поделиться