Watchdog (osx) не уведомляет об изменениях в удаленной сети - PullRequest
7 голосов
/ 29 февраля 2012

Я использую 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, так как он говорит, что предпочитает сначалаСторожевой таймер)?

Я был потрясен этим пакетом 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

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

1 Ответ

6 голосов
/ 29 февраля 2012

Я почти уверен, что события файловой системы не работают через NFS - причина в том, что способ, которым ядро ​​обычно управляет событиями файловой системы, состоит в том, что у него есть слой в ядре, который запускает активность - в NFS нет возможности для уведомляя об изменениях, вы можете только получить список inode, написать несколько блоков, прочитать некоторые блоки и т. д. Это довольно минимально.

Чтобы события файловой системы работали через NFS, вам необходимо постоянно опрашивать сервер NFS.

Возможно, для AFP предусмотрены некоторые возможности, которые, если у вас есть сок, вы можете просто установить netatalk и попробовать.

Если вам абсолютно необходимо сделать что-то подобное, а netatalk этого не делает - лучше всего запустить и запустить OSXFuse и написать наложение NFS, которое на самом деле просто сидит и запрашивает изменения. Но вы будете ограничены «усеченным, измененным, добавленным, удаленным» и т. Д.

См. Также: Использовать libfuse в проекте без root-доступа (для установки)? FTP монтирует и inotify / kqueue / FSEvents

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...