监视程序观察者未在容器

时间:2018-04-24 20:40:04

标签: python-3.x docker python-watchdog

我使用watchdog来监视文件系统事件的文件目录。如果此 watcher 脚本检测到某个事件,我想在数据库中创建一个条目(在本例中为Mongodb)。要监视的文件系统实际上是一个Docker卷,它将文件系统链接到我的主机pc。所有代码都在docker容器中运行。我可以附加到系统中的任何容器,并使用pymongo正确添加数据库的条目。

我还可以在主机上运行 watcher 并且所有工作都按预期工作(包括如果容器中链接文件系统对文件系统进行了更改,则按预期执行。

但是,当我在容器中运行观察程序代码时,似乎永远不会调用由文件系统事件触发的事件处理程序中的方法。当然没有创建db条目。

有3个代码来源:

  1. 看门狗目录'观察者'包括观察者和处理程序 [watchdog_classes]

    import time
    from watchdog.observers import Observer
    import watchdog.events as events
    from data_persist import persistance_interface
    
    db_interface= persistance_interface()
    
    class RepoWatcher:
    
    
    
       def __init__(self, dir_root='/targer_dir/'):
            print(dir_root)
            self.observer = Observer()
            self.dir_root = dir_root
    
        def run(self):
            event_handler = CustomEventHandler()
            self.observer.schedule(event_handler, self.dir_root, recursive=True)
            self.observer.start()
            try:
                while True:
                    time.sleep(5)
            except KeyboardInterrupt:
                self.observer.stop()
                print("Shutting down...")
    
            self.observer.join()
    
    class CustomEventHandler(events.FileSystemEventHandler):
        @staticmethod
        def on_any_event(event):
    
            # Renamed files or dirs
            if isinstance(event, events.FileSystemMovedEvent):
                print("moved")
                db_interface.persist_one({'rename': 'renamed'})
    
            # Created files or dirs
            elif event.event_type == 'created':
                print("created")
                db_interface.persist_one({'create': 'creation'})
    
            # Deleted files or dirs
            elif isinstance(event, events.FileDeletedEvent):
                print("deleted")
                db_interface.persist_one({'deletion': 'deleted'})
    
  2. 用于写入Mongodb的类 [data_persist module]

    import pymongo
    from pymongo import MongoClient
    
    class persistance_interface():
        def __init__(self):
        self.client = MongoClient('db', 27017)
        self.db = self.client.filesystemeventsdb
        self.filesystemevents_collection = self.db.filesystemevents_collection
    
    def persist_one(self, data):
        self.asset_collection.insert_one(data)
    
  3. 触发观察者的脚本 [watcher.py]

    import watchdog_classes
    
    watcher = watchdog_classes.RepoWatcher()
    watcher.run()
    
  4. 我在同一个Docker容器中运行3个代码源,mongodb在另一个容器中。

    docker-compose.yaml看起来像这样:

    version: '3'
    services:
    
      db:
        image: tutum/mongodb
        ports:
          - "27017:27017"
        environment:
          - AUTH=no
        entrypoint: "usr/bin/mongod"
    
      sentry:
        build: ./Docker/sentry
        entrypoint: "python -u run_watcher.py"
        volumes:
          - "C:\\Users\\username\\Desktop\\HostVolume:/Container_Volume"
    
      web:
        build: ./Docker/site
        ports:
          - "8000:8000"
        command: python -u manage.py runserver 0.0.0.0:8000
        volumes:
          - "C:\\Users\\username\\Desktop\\HostVolume:/Container_Volume"
    
      

    为什么没有调用看门狗处理程序事件?

1 个答案:

答案 0 :(得分:2)

似乎我的问题的来源不在我的代码中,但 Docker for windows不会通知容器有关您从Windows 所做的任何文件更改。这意味着只有容器内容量的变化才可见。

我找到了一个解决方法here,但它要求主机目录连续运行脚本。不理想,但至少不行。